【C++ 二维前缀和】约会

题目描述

从前,小兔发现了一个神秘的花园。

花园是一个 n 行 m 列的矩阵,第 i 行 j 列的花的美丽度为 ai,j,一个合法的约会场所为任意一个正方形子矩阵,定义子矩阵的浪漫度为这个子矩阵的两条对角线上的花的美丽度之和。

现在小兔想选一个面积大等于 1 的约会场所使得场所的浪漫度最大,以便和小鹿约会,因为小兔忙着 AKIOI ,所以她把这个问题交给了你。

输入

第一行,两个正整数 n,m。

接下来是一个 n 行 m 列的矩阵,表示各个位置上花的美丽度。

输出

仅一行,一个正整数,表示最大的浪漫度。

样例输入 Copy
复制代码
3 3
2 -1 3
-4 2 1
1 2 -1
样例输出 Copy
复制代码
7
提示

对于 40%的数据,n,m≤10。

对于 100%的数据,1≤n,m≤300,∣ai∣≤104。

cpp 复制代码
#include <cstdio>
#include <climits>
int a[310][310];
long long sumz[310][310],sumf[310][310];
long long ans = LLONG_MIN;
int main()
{
	int n, m;
	scanf("%d%d", &n, &m);
	for (int i = 1; i <= n; i++)
	{
		for (int j = 1; j <= m; j++)
		{
			scanf("%d", &a[i][j]);
			sumz[i][j] = sumz[i - 1][j - 1] + a[i][j];
			sumf[i][j] = sumf[i - 1][j + 1] + a[i][j];
		}
	}
	int b = m < n ? m : n, temp;
	for (int k = 1; k <= b; k++)
	{
		for (int i = 1; i <= n - k + 1; i++)
		{
			for (int j = 1; j <= m - k + 1; j++)
			{
				temp = sumz[i + k - 1][j + k - 1] - sumz[i - 1][j - 1] 
                     + sumf[i + k - 1][j] - sumf[i - 1][j + k];
				if(k & 1) 
                    temp -= a[((i << 1) + k - 1) >> 1][((j << 1) + k - 1) >> 1];
				if (temp > ans) ans = temp;
			}
		}
	}
	printf("%lld\n", ans);
	return 0;
}
相关推荐
Irissgwe1 小时前
类与对象(三)
开发语言·c++·类和对象·友元
️是781 小时前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin1 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾1 小时前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困1 小时前
leetGPU
算法
雪度娃娃1 小时前
转向现代C++——优先选用nullptr而不是0和NULL
开发语言·c++
我星期八休息2 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛2 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你912 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i3 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪