二維數組之最大聯通和(聯通塗色問題) beta!

來源:互聯網
上載者:User

標籤:

不完美版本一

#include<iostream>using namespace std;/*int yiwei_max(int n,int a[],int *p,int *q){     int temp=0,sum=-999999999,timer=-1;     for(int i=0;i<n;i++)     {         if(temp>0)         {             temp+=a[i];         }         else          {             temp=a[i];         }         if(temp>sum)          {             sum=temp;             *q=i;             timer++;         }     }     *p=*q-timer;     return sum;  }*/int max_sum(int n,int a[],int *besti,int *bestj){     int *b = (int *)malloc(n * sizeof(int));     int sum = 0;     int i = -1;     int temp = 0;     for (i=0;i<=n-1;i++)      {          if (temp > 0)          {              temp += a[i];          }          else          {              temp = a[i];          }          b[i] = temp;     }     sum = b[0];     for (i=1;i<=n-1;i++)      {         if (sum < b[i])          {             sum = b[i];             *bestj = i;         }     }     for (i = *bestj;i >= 0;i--)     {        if (b[i] == a[i])         {             *besti = i;             break;        }    }    free(b);    return sum; }void main(){    int a[100][100],b[100];    int up[100],down[100],t[100];    int i,j,m,n,x,y;    int temp,t2;    int l=0,u=0,l_down,l_up,n_down,n_up;    int s;    cout<<"幾行幾列?"<<endl;    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];        }        //temp=yiwei_max(n,b,&x,&y);        temp=max_sum(n,b,&x,&y);        up[i]=x;        down[i]=y;        t[i]=temp;    }    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];        }        else        {            l_down=down[i];            l_up=up[i];            n_up=up[i+1];            n_down=down[i+1];                        if(down[i]<up[i+1])            {                for(;l_down!=up[i+1];)                {                    l+=a[i][++l_down];                        }                                for(;n_up!=down[i];)                {                    u+=a[i+1][--n_up];                }            }            if(up[i]>down[i+1])            {                for(;l_up!=down[i+1];)                {                    l+=a[i][--l_up];                        }                for(;n_down!=up[i];)                {                    u+=a[i+1][++n_down];                }            }                        s=l>u?l:u;            if(s+t[i+1]>0)            {                t2+=t[i+1]+s;            }        }    }    cout<<t2<<endl;}

 

二維數組之最大聯通和(聯通塗色問題) beta!

聯繫我們

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