標籤:
題目:返回一個二維整數數組中最大聯通子數組的和
結對夥伴:丁官甲
部落格地址: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總結:這次我們花了比上次多一倍的時間終於完成。
返回一個二維整數數組中最大聯通子數組的和