对网上最大字段和dp解法建模的勘误

来源:互联网 发布:新塘拿网络授权 编辑:程序博客网 时间:2024/05/16 00:50

设有array[1~n],求最大字段和。

而网上的说法是b[j]是array[1~j]的最大字段区间。如果这是子问题,那么当j=n,则b[j]就是最终结果,显然不是这样,不然sum变量是做什么的呢,何况b[n]也没被用来做最终结果。

实际上这个问题的线性解法描述应该是这样的。

有一串数字,程序从头依次逐个地读取。

(1)若这个数是负数,则舍弃继续往下读。

(2)如果是正数,则从这个数开始与后面的数累加,直到小于0,则整体可看做一个负数,舍弃继续往下读。

设变量max,每个(1)过程取max(这个负数,max),每个(2)过程取x次max(sum,max)即取max(sum峰值,max)

这也应该算一种规律吧。

 public int maxSubArray(int n,int a[])    {        int b=0,sum=-10000000;        for(int i=0;i< n;i++)        {             if(b>0) b+=a[i];             else b=a[i];             if(b>sum) sum=b;         }        return sum;    }

poj 1050

#include<iostream>#include<fstream>using namespace std;int n;int a[101][101];int b[101][101];//int res[101][101];int res;int sum;int main(){cin>>n;for(int i=0;i<n;i++){for(int j=0;j<n;j++){cin>>a[i][j];}}memset(b,0,sizeof(b));//memset(res,-10000,sizeof(res));res=-10000;for(int i=0;i<n;i++){for(int j=0;j<n;j++){sum=0;for(int k=j;k<n;k++){sum+=a[i][k];if(b[j][k]>0){b[j][k]+=sum;}else{b[j][k]=sum;}//res[j][k]=max(res[j][k],b[j][k]);res=max(res,b[j][k]);}}}cout<<res<<endl;return 0;}



原创粉丝点击