51nod-dp入门-最大子矩阵和
2016-04-23 20:00
218 查看
思路见51nod。
代码附上:#include <stdio.h>
#include <cstring>
using namespace std;
typedef long long ll;
const int MAX=510;
int m,n;
ll a[MAX][MAX],c[MAX];
int main(){
while(~scanf("%d%d",&m,&n)){
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
scanf("%I64d",&a[i][j]);
}
}
memset(c,0,sizeof(c));
ll res=0,ans=0;
for(int i=0;i<n;i++){
for(int j=i;j<n;j++){
res=0;
for(int k=0;k<m;k++){
c[k]=(j==i)?a[i][k]:c[k]+a[j][k];
if(res>0) res+=c[k];
else res=c[k];
if(res>ans) ans=res;
}
}
}
printf("%I64d\n",ans );
}
return 0;
}
代码附上:#include <stdio.h>
#include <cstring>
using namespace std;
typedef long long ll;
const int MAX=510;
int m,n;
ll a[MAX][MAX],c[MAX];
int main(){
while(~scanf("%d%d",&m,&n)){
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
scanf("%I64d",&a[i][j]);
}
}
memset(c,0,sizeof(c));
ll res=0,ans=0;
for(int i=0;i<n;i++){
for(int j=i;j<n;j++){
res=0;
for(int k=0;k<m;k++){
c[k]=(j==i)?a[i][k]:c[k]+a[j][k];
if(res>0) res+=c[k];
else res=c[k];
if(res>ans) ans=res;
}
}
}
printf("%I64d\n",ans );
}
return 0;
}
相关文章推荐
- java --Arrays的equals
- 使用 redis_builder 管理 redis 集群
- CSU 1541 There is No Alternative(最小生成树+枚举)
- JS stopPropagation()
- While reading XXX pngcrush caught libpng error: N
- C、C++、ANDROID、JAVA各有什么区别?
- 51nodLearning-dp入门之循环数组的最大子段和
- Node.js流
- java--previousIndex()
- Python 程序设计语言 笔记(七)
- 秒杀设计--mysql的锁机制应用和redis方案
- 不包含继承时类中的静态块、静态方法、非静态方法、构造函数的执行顺序?
- AFNetWorking https请求 SSL认证 自制证书
- Xcode本地文件 提交svn 的明细
- 浙江16年省赛 I题 People Counting
- Android_Message 源码解读
- LeetCode Same Tree 100
- HBase读与写数据流程
- JAVAEE项目结构以及并发随想
- Object-C 基础学习(二)