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

來源:互聯網
上載者:User

標籤:

要求:

  輸入一個二維整形數組,數組裡有正數也有負數。

  二維數組首尾相接,象個一條首尾相接帶子一樣。

  數組中連續的一個或多個整數組成一個子數組,每個子數組都有一個和。

  求所有子數組的和的最大值。

【轉】設計思路:

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

 

【轉】原始碼:

#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;}

 

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.