连通最大子数组和(结对开发)

题目:返回一个二维数组中最大子数组的和(连通性)

合作伙伴:张江鹏    博客地址:http://home.cnblogs.com/u/gaara-zhang/

设计思路:把数按行分成几个一维数组,对于该一维数组,求出他们的最大连续数组之和,并且记录下最大连续数组的第一位和最后一位的位置,之后判断几个一维数组的最大 连续数组的位置是否相接或包括(如,第一行是1和4,第二行是3和5,这样就相连)。最后在加上没有包括的正数(必须在上一行的最大连续数组的第一位和最 后一位的位置之间)。输出之前之和就行。

#include<iostream>
using namespace std;
  
int Max(int n,int a[],int *smark,int *mmark)
{
    int b[100]={0};
    int i,sum1=0,max1=0;
    for(i=0;i<n;i++)
    {
        if(sum1<0)
        {
            sum1=a[i];
        }
        else
        {
            sum1=sum1+a[i];
        }
        b[i]=sum1;
    }
    max1=b[0];
    for(i=0;i<n;i++)
    {
        if (max1<b[i])
         {
             max1= b[i];
             *mmark = i;
         }
    }
     for (i = *mmark;i >= 0;i--)
    {
        if (b[i] == a[i])
        {
             *smark = i;
             break;
        }
    }
     return max1;
}
  
void main()
{
    int m,n,i,j,smark,mmark,t2;
    int sum,max;
    int up[100],down[100],t[100];
    int a[100][100],b[100];
    cout<<"输入二维数组的行和列";
    cin>>m>>n;
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
        {
            cin>>a[i][j];
        }
    }
  
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
        {
            b[j]=a[i][j];
        }
        sum=Max(n,b,&smark,&mmark);
        up[i]=smark;                                  
        down[i]=mmark;
        t[i]=sum;
  
    }
    t2=t[0];
    for(i=0;i+1<m;i++)
    {
        if(up[i]<=down[i+1] && down[i]>=up[i+1])
        {
            t2+=t[i+1];
        }
         for(j=up[i];j<up[i+1];j++)
        {
            if(a[i+1][j]>0) t2+=a[i+1][j];                   //判别独立正数
        }
  
    }
     cout<<t2<<endl;
  
}

posted @ 2016-04-06 15:23  无痕公子的丸子头  阅读(126)  评论(1编辑  收藏  举报