uva10827Maximum sum on a torus

简介: 题意:给定一个矩阵,每个元素可正可负,求最大子矩阵使得其所有元素和最大。给定的矩阵是环形的,即:第一列和最后一列是相连接的,第一行和最后一行也是相连接的。 分析:构造前缀和。O(n4)的效率不是很满意,期待更快的算法 View Code 1 #include 2 #includ...

题意:给定一个矩阵,每个元素可正可负,求最大子矩阵使得其所有元素和最大。给定的矩阵是环形的,即:第一列和最后一列是相连接的,第一行和最后一行也是相连接的。

分析:构造前缀和。O(n4)的效率不是很满意,期待更快的算法

View Code
 1 #include <stdio.h>
 2 #include <iostream>
 3 using namespace std;
 4 const int MAXN = 160;
 5 #define DEBUG
 6 int a[MAXN][MAXN], b[MAXN], c[MAXN];
 7 int main(){
 8 #ifndef DEBUG
 9     freopen("in.txt", "r", stdin);
10 #endif
11     int cas, n;
12     scanf("%d", &cas);
13     while(cas--){
14         scanf("%d", &n);
15         int i, j;
16         for(i=0; i<n; i++)
17             for(j=0; j<n; j++){
18                 scanf("%d", &a[i][j]);
19                 a[i][j+n]=a[i+n][j]=a[i+n][j+n]=a[i][j];
20             }
21         int ans = -0X3F3F3F3F;
22         int x, y;
23         for(x=0; x<n; x++)
24             for(y=0; y<n; y++)
25                 for(i=0; i<n; i++)
26                     for(j=0; j<n; j++){
27                         c[j]=a[i+x][y+j];
28                         if(j>0) c[j]+=c[j-1];
29                         if(i>0) b[j]+=c[j];
30                         else b[j]=c[j];
31                         if(ans<b[j]) ans=b[j];
32                     }
33         printf("%d\n", ans);
34     }
35     return 0;
36 }

 

目录
相关文章
LeetCode 64. Minimum Path Sum
给定m x n网格填充非负数,找到从左上到右下的路径,这最小化了沿其路径的所有数字的总和。 注意:您只能在任何时间点向下或向右移动。
100 0
LeetCode 64. Minimum Path Sum
LeetCode 209. Minimum Size Subarray Sum
给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组。如果不存在符合条件的连续子数组,返回 0。
115 0
LeetCode 209. Minimum Size Subarray Sum
Maximum Subsequence Sum
最大连续子列和问题,在此给出题解 (浙大PTA https://pintia.cn/problem-sets/16/problems/665)
LeetCode之Max Consecutive Ones
LeetCode之Max Consecutive Ones
133 0
|
人工智能 机器学习/深度学习
1007. Maximum Subsequence Sum (25)
简析:求最大子列和,并输出其首末元素。在线处理,关键在于求首末元素。 本题囧,16年9月做出来过,现在15分钟只能拿到22分,有一个测试点过不了。
974 0