激光炸弹
题意
输出仅有一个正整数,表示一颗炸弹最多能炸掉地图上总价值为多少的目标
思路
- 输出所需值
- 二维前缀和模板输入
- 输出结果
代码
#include<bits/stdc++.h>
using namespace std;
int main(){
int n,m;
cin>>n>>m;
int a[5010][5010]={0};
for(int i=0;i<n;i++){
int x,y,v;
cin>>x>>y>>v;
a[x][y]=v;
}
int ans=0;
for(int i=0;i<5010;i++){
for(int j=0;j<5010;j++){
if(i!=0){
a[i][j]+=a[i-1][j];
}
if(j!=0){
a[i][j]+=a[i][j-1];
}
if(i!=0&&j!=0){
a[i][j]-=a[i-1][j-1];
}
}
}
for(int i=0;i<5010;i++){
for(int j=0;j<5010;j++){
int sum=a[i][j];
if(i-m>=0){
sum-=a[i-m][j];
}
if(j-m>=0){
sum-=a[i][j-m];
}
if(i-m>=0&&j-m>=0){
sum+=a[i-m][j-m];
}
ans=max(ans,sum);//取最大值
}
}
cout<<ans<<endl;
}
总结
运用到二维前缀和