返回一個二維整數數組中最大聯通子數組的和

來源:互聯網
上載者:User

標籤:

題目:返回一個二維整數數組中最大聯通子數組的和

結對夥伴:丁官甲

部落格地址:http://www.cnblogs.com/dgj1314/

部落格名:與誠

 

1 問題:返回一個二維整數數組中最大聯通子數組的和

2 思路:對n*m的二維數組進行分解,分解為n個一維數組,再先求這n個一維數組的最大子數組和,並記下每行最大一維子數組的下標如2-5,這是就會分兩種情況第一種是行之間的最大子數組是相連的,如第一行是2-5,第二行是3-6,這是直接相加就                 行。第二種是不相連的如第一行是2-5,第二行是6-7,這時候就把每行的最大子數組看成一個整體,再使每個最大數組塊進行相連,求使其相連的最小代價。最後就可求出最大聯通子數組的和。

3代碼:

#include<iostream>using namespace std;int zuida(int n,int a[],int *sm,int *mm);void main(){    int m,n,i,j,sm,mm,t2;    int sum,max;    int up[100],down[100],t[100];    int a[100][100],b[100];    cout<<"輸入二維數組的行"<<endl;    cin>>m;     cout<<"輸入二維數組的行"<<endl;     cin>>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=zuida(n,b,&sm,&mm);        up[i]=sma;                                           down[i]=mm;        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; }int zuida(int n,int a[],int *sm,int *mm){    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];             *mm = i;         }    }     for (i = *mm;i >= 0;i--)    {        if (b[i] == a[i])        {             *sm= i;             break;        }    }     return max1;}
4總結:這次我們花了比上次多一倍的時間終於完成。

 


返回一個二維整數數組中最大聯通子數組的和

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.