BZOJ 1218: [HNOI2003]激光炸弹 前缀DP

时间:2021-12-31 00:40:52

1218: [HNOI2003]激光炸弹

Description

一种新型的激光炸弹,可以摧毁一个边长为R的正方形内的所有的目标。现在地图上有n(N<=10000)个目标,用整数Xi,Yi(其值在[0,5000])表示目标在地图上的位置,每个目标都有一个价值。激光炸弹的投放是通过卫星定位的,但其有一个缺点,就是其爆破范围,即那个边长为R的正方形的边必须和x,y轴平行。若目标位于爆破正方形的边上,该目标将不会被摧毁。 0

Input

输入文件的第一行为正整数n和正整数R,接下来的n行每行有3个正整数,分别表示

Output

输出文件仅有一个正整数,表示一颗炸弹最多能炸掉地图上总价值为多少的目标(结果不会超过32767)。

Sample Input

2 1
0 0 1
1 1 1

Sample Output

1

HINT

 题解:  求出a[i][j]代表从(1,1)到(i,j)这个矩阵的总价值和
    再枚举R*R的矩形就好了  题目给了10S,放心暴力
//meek///#include<bits/stdc++.h>
#include <iostream>
#include <cstdio>
#include <cmath>
#include <string>
#include <cstring>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <stack>
#include <sstream>
#include <vector>
using namespace std ;
#define mem(a) memset(a,0,sizeof(a))
#define pb push_back
#define fi first
#define se second
#define MP make_pair
typedef long long ll; const int maxn=+;
const int inf = ;
const int mod= ; int n,R,x,y,c,a[maxn][maxn];
int main() {
int N = ;
scanf("%d%d",&n,&R);
for(int i=;i<=n;i++) {
scanf("%d%d%d",&x,&y,&c);
a[x+][y+]=c;
}
for(int i=;i<=N;i++) {
for(int j=;j<=N;j++) a[i][j]+=a[i-][j]+a[i][j-]-a[i-][j-];
}
N-=R;
int ans=-;
for(int i=;i<=N;i++) {
for(int j=;j<=N;j++) ans=max(ans,a[i+R][j+R]-a[i][j+R]-a[i+R][j]+a[i][j]);
}
cout<<ans<<endl;
return ;
}

代码

BZOJ 1218: [HNOI2003]激光炸弹 前缀DP的更多相关文章

  1. BZOJ 1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹&lpar; 前缀和 &plus; 枚举 &rpar;

    虽然source写着dp , 而且很明显dp可以搞...但是数据不大 , 前缀和 + 枚举也水的过去..... -------------------------------------------- ...

  2. bzoj 1218 &lbrack;HNOI2003&rsqb;激光炸弹 二维前缀和

    [HNOI2003]激光炸弹 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3022  Solved: 1382[Submit][Status][Di ...

  3. BZOJ 1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹(二维前缀和)

    Description 一种新型的激光炸弹,可以摧毁一个边长为R的正方形内的所有的目标.现在地图上有n(N<=10000)个目标,用整数Xi,Yi(其值在[0,5000])表示目标在地图上的位置 ...

  4. &lbrack;BZOJ 1218&rsqb; &lbrack;HNOI2003&rsqb; 激光炸弹 【n logn 做法 - 扫描线 &plus; 线段树】

    题目链接:BZOJ - 1218 题目分析 可以覆盖一个边长为 R 的正方形,但是不能包括边界,所以等价于一个边长为 R - 1 的正方形. 坐标范围 <= 5000 ,直接 n^2 的二维前缀 ...

  5. bzoj 1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹

    思路:二维前缀和, 枚举矩形左上端点. #include<bits/stdc++.h> #define LL long long #define fi first #define se s ...

  6. bzoj1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹(DP二维前缀和)

    1218: [HNOI2003]激光炸弹 题目:传送门 题解: 一道经典题目啊... 为了更好的操作...把整个坐标系向右上角移动,从(1,1)开始 那么f[i][j]统计一下以(i,j)作为右上角, ...

  7. 1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹

    1218: [HNOI2003]激光炸弹 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1139  Solved: 542[Submit][Statu ...

  8. 【BZOJ】1218&colon; &lbrack;HNOI2003&rsqb;激光炸弹(前缀和)

    题目 题目描述 输入输出格式 输入格式: 输入文件名为input.txt 输入文件的第一行为正整数n和正整数R,接下来的n行每行有3个正整数,分别表示 xi,yi ,vi . 输出格式: 输出文件名为 ...

  9. 洛谷P2280 &lbrack;HNOI2003&rsqb; 激光炸弹 &lbrack;前缀和&rsqb;

    题目传送门 题目描述 输入输出格式 输入格式: 输入文件名为input.txt 输入文件的第一行为正整数n和正整数R,接下来的n行每行有3个正整数,分别表示 xi,yi ,vi . 输出格式: 输出文 ...

随机推荐

  1. MySQL中VARCHAR与CHAR格式数据的区别

    区别 CHAR与VARCHAR类型类似,但它们保存和检索的方式不同.CHAR有固定的长度,而VARCHAR属于可变长的字符类型.它们最大长度和是否尾部空格被保留等方面也不同.在存储和检索过程中不进行大 ...

  2. 【CodeForces 697B】Barnicle

    对科学计数法表示的数,输出其10进制的形式. c++来做,需要考虑这些细节: 当b==0,d==0时,只输出a. 当不需要补零的情况有两种: 一种是刚好是整数,只输出a(注意1.0e1的情况是输出1) ...

  3. sublime text 个性设置

    http://*.com/questions/13781833/sublime-text-2-how-to-change-the-font-size-of-the-file-s ...

  4. grootJs 属性过滤器

    index10.html <html><head> <title>属性过滤器</title> <script src="jquery-1 ...

  5. Impala:新一代开源大数据分析引擎

    Impala架构分析 Impala是Cloudera公司主导开发的新型查询系统,它提供SQL语义,能查询存储在Hadoop的HDFS和HBase中的PB级大数据.已有的Hive系统虽然也提供了SQL语 ...

  6. iOS-联系人应用(一)

    环境:xcode6,iphone 4s simulator with iOS8.0 一.功能界面介绍 1.1 应用启动进入联系人列表页面,数据为模拟数据,来源与一个plist文件: 1.2 点击右上角 ...

  7. 关于win8的各种版本的区别

    Windows8.1 Professional VL  表示:专业版(大客户版,批量授权) Windows8.1 Multiple editions 表示:多合一版本(包含:标准版.专业版) 个人用户 ...

  8. 项目实战工具类(二):ZipUtils&lpar;压缩&sol;解压缩文件相关&rpar;

    import android.content.Context; import android.util.Log; import java.io.File; import java.io.FileInp ...

  9. &lbrack;阮一峰&rsqb;Linux 守护进程的启动方法

    "守护进程"(daemon)就是一直在后台运行的进程(daemon). 本文介绍如何将一个 Web 应用,启动为守护进程. 一.问题的由来 Web应用写好后,下一件事就是启动,让它 ...

  10. mavenLocal默认地址转移

    maven的默认本地仓库为 USER_HOME/.m2/ windows开发我们大多不会讲本地仓库放在c盘下,而是重新指定了另一个存储位置. 在gradle中 使用 mavenLocal() 时的查找 ...