蓝桥杯 最大子阵 dp (类最大连续子段和)

来源:互联网 发布:windows影音制作xp版 编辑:程序博客网 时间:2024/05/21 09:40

题目链接


思路:

这个题我觉得还是不错的,当然我是想不到的.

    我们这个题可以把它类比成一维的求最大连续子段和的问题,

    也就是说对于要求的这个子矩阵,我们可以预处理出来他一列一列的和,然后我们可以O(n^2)枚举矩阵的高,比如i,j那么高为j-i+1,由于我们预处理了列的和,那么对于每一列的和可以看成一个一维的了.就转化成了求最大连续子段和.


   

     

#include<bits/stdc++.h>#define Ri(a) scanf("%d", &a)#define Rl(a) scanf("%lld", &a)#define Rf(a) scanf("%lf", &a)#define Rs(a) scanf("%s", a)#define Pi(a) printf("%d\n", (a))#define Pf(a) printf("%lf\n", (a))#define Pl(a) printf("%lld\n", (a))#define Ps(a) printf("%s\n", (a))#define W(a) while(a--)#define CLR(a, b) memset(a, (b), sizeof(a))#define MOD 1000000007#define inf 0x3f3f3f3fusing namespace std;typedef long long ll;const int maxn=1e5+10;int sum[555][555],dp[555],b[555];int n,m,k; int main(){Ri(n),Ri(m);CLR(sum,0);for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){Ri(k);sum[i][j]=sum[i-1][j]+k;}}int ans=-inf;for(int i=1;i<=n;i++){for(int j=i;j<=n;j++){for(int w=1;w<=m;w++){b[w]=sum[j][w]-sum[i-1][w];//Pi(b[w]);}//puts("");dp[1]=b[1];ans=max(dp[1],ans);//最大子段和for(int z=2;z<=m;z++){if(dp[z-1]<0)dp[z]=b[z];elsedp[z]=dp[z-1]+b[z];ans=max(ans,dp[z]);}}}Pi(ans); return 0; }

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 胆囊胆管都结石怎么办 肾里面有肿瘤怎么办 肾癌手术后发烧怎么办 尿结石堵住尿道怎么办 尿结石不能排尿怎么办 肾癌小便有血怎么办 膀胱癌膀胱全切怎么办 怀孕了有阑尾炎怎么办 食物堵塞在食管怎么办 食物卡在食管怎么办 小孩食道卡异物怎么办 八十岁老人得了膀胱癌怎么办 肾结石引起吐血尿血怎么办 肾结石引起的尿血怎么办 食道感觉有异物怎么办 膀胱出血有血块怎么办 肾小球滤过率20怎么办 膀胱癌术后有血尿怎么办 肾病贫血怎么办吃什么 低蛋白血症怎么办 慢性肾炎患者感冒了怎么办 透析病人磷高怎么办 尿毒症透析磷高怎么办 怀孕了有膀胱炎怎么办 宝宝拉肚子尿少怎么办 猫尿血怎么办吃什么药 肝癌小便不出来怎么办 怀孕三个月结石血尿怎么办? 肾小球滤过率65怎么办 肾穿后有血肿6cm怎么办 肾穿刺后血肿怎么办 手术后有血肿怎么办 尿蛋白胆红素高怎么办 哺乳期尿蛋白高怎么办 产后老放屁便秘怎么办 肝癌移植后复发怎么办 产后屁多便秘怎么办 肝癌切除后复发怎么办 宝宝便秘拉不出大便怎么办 宝宝便秘屁多怎么办 尿液浑浊气味重怎么办