| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 429 人关注过本帖
标题:在线处理求最大序列和
取消只看楼主 加入收藏
令狐少侠56
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:320
专家分:175
注 册:2014-4-10
结帖率:58.18%
收藏
 问题点数:0 回复次数:2 
在线处理求最大序列和
明天试试分治法,分治的话代码可能要难写一些
原题
图片附件: 游客没有浏览图片的权限,请 登录注册

程序代码:
#include<stdio.h>

int Compare(int CurArraySum,int MaxArraySum)
{
    if( CurArraySum > MaxArraySum )
        MaxArraySum=CurArraySum;

    return MaxArraySum;
}

int main()
{
    int Array[100000];
    int CurArraySum,MaxArraySum;
    int k,i;
    int book; //记录Array[]中负数的个数

    book=0;
    CurArraySum=0;
    MaxArraySum=-9999999;

    scanf("%d",&k);

    for(i=0;i<k;i++)
    {
        scanf("%d",&Array[i]);
    }

    //在线处理,扫描下一个数与最大和比较,当前和为负数则不将当前和记录至下一个数,重置后扫描
    for(i=0;i<k;i++)
    {
        if(Array[i]<0) book++; 

        if( CurArraySum<0 )
        {
            CurArraySum=0;
            CurArraySum+=Array[i];//重新扫描
            MaxArraySum = Compare( CurArraySum , MaxArraySum );
        }
        else 
        {
            CurArraySum+=Array[i];//虽然第一项为负数时会将其包含进CurArraySum,但是后会被重置为0,即使只有一项由于book的记录也会输出0
            MaxArraySum = Compare( CurArraySum , MaxArraySum );
        }
    }

    if(book==k)
        printf("0\n");
    else
        printf("%d\n",MaxArraySum);
return 0;
}



2015-10-23 21:57
令狐少侠56
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:320
专家分:175
注 册:2014-4-10
收藏
得分:0 
回复 2楼 wmf2014
我觉得直接给出代码不好。就在这个版写了。
2015-10-24 07:51
令狐少侠56
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:320
专家分:175
注 册:2014-4-10
收藏
得分:0 
回复 5楼 azzbcc
动态规划以前看过,还不会列转移方程。。
2015-10-24 18:10
快速回复:在线处理求最大序列和
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.031668 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved