AcWing 99. 激光炸弹
原题链接
简单
作者:
好烂人
,
2025-03-31 22:10:05
· 江苏
,
所有人可见
,
阅读 2
#include<iostream>
using namespace std;
const int N = 5e3 + 10;
int n, r;
int s[N][N];
int main()
{
cin>>n>>r;
r = min(5001, r);
for(int i = 0; i < n; i ++)
{
int x, y, w; cin>>x>>y>>w;
s[++x][++y] += w;
}
for(int i = 1; i <= 5001; i ++)
{
for(int j = 1; j <= 5001; j ++)
{
s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + s[i][j];
}
}
int res = 0;
for(int i = r; i <= 5001; i ++)
{
for(int j = r; j <= 5001; j ++)
{
int temp = s[i][j] - s[i - r][j] - s[i][j - r] + s[i - r][j - r];
res = max(temp, res);
}
}
cout<<res;
return 0;
}