题目名字
https://www.luogu.com.cn/problem/P2280
题意
炸弹可以摧毁一个边长为m的正方形内的所有目标。地图上有n个目标,每个目标有坐标(x,y)和价值v。现在需要计算一颗炸弹最多能炸掉地图上总价值为多少的目标。
思路
- 读取输入,包括n、m和每个目标的坐标和价值。
- 针对每个目标,计算其所在的正方形范围内的其他目标的总价值。
- 找到所有正方形范围内价值最大的目标组合。
输出这个最大总价值。
坑点
- 边界情况:要确保考虑到所有可能的边界情况,包括目标与爆炸范围边界相交或者完全包含在范围内的情况。
算法一:XX+XX
二维前缀和
实现步骤
- 读取输入,包括n、m和每个目标的坐标和价值。
- 遍历所有目标,计算其与其他目标组成的正方形范围内的目标价值总和,将每个目标的正方形范围内的目标价值总和保存到一个二维数组中。
- 找到所有正方形范围内价值最大的目标组合。
5.将这些价值最大的目标保存到一个集合中,遍历其所在正方形范围内的其他目标,找到价值最大的组合。
6输出这个最大总价值。
代码
#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;
}