社区讨论

求助P2280激光炸弹

题目总版参与者 3已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@lo226xeb
此快照首次捕获于
2023/10/23 06:47
2 年前
此快照最后确认于
2023/11/03 07:08
2 年前
查看原帖
CPP
请问第二个for循环,i和j为什么从m + 1开始呢?坐标加1之后s数组有意义的部分应该从
[1][1]开始吧
#include<bits/stdc++.h>
using namespace std;
const int N = 5001;

int n, m, ans = 0;
int s[5010][5010];

int main()
{
	cin >> n >> m;
	for(int i = 0;i < n;i++)
	{
		int x, y, c;
		cin >> x >> y >> c;
		s[x + 1][y + 1] = c;
	}
	
	for(int i = 1;i <= N;i++)
		for(int j = 1;j <= N;j++)
		s[i][j] = s[i][j - 1] + s[i - 1][j] - s[i - 1][j - 1] + s[i][j];
		
	
	for(int i = m + 1;i <= N;i++)
	{
		for(int j = m + 1;j <= N;j++)
		{
			ans = max(ans, s[i][j] - s[i - m][j] - s[i][j - m] + s[i - m][j - m]);
		}
	}
	
	cout << ans << endl;
	
	
	return 0;
}

回复

3 条回复,欢迎继续交流。

正在加载回复...