每日一题 AcWing 99.激光炸弹

2023-10-27

题目:

地图上有 N 个目标,用整数 Xi,Yi 表示目标在地图上的位置,每个目标都有一个价值 Wi。

注意:不同目标可能在同一位置。

现在有一种新型的激光炸弹,可以摧毁一个包含 R×R 个位置的正方形内的所有目标。

激光炸弹的投放是通过卫星定位的,但其有一个缺点,就是其爆炸范围,即那个正方形的边必须和 x,y 轴平行。

求一颗炸弹最多能炸掉地图上总价值为多少的目标。

输入格式

第一行输入正整数 N 和 R,分别代表地图上的目标数目和正方形的边长,数据用空格隔开。

接下来 N 行,每行输入一组数据,每组数据包括三个整数 Xi,Yi,Wi,分别代表目标的 x 坐标,y 坐标和价值,数据用空格隔开。

输出格式

输出一个正整数,代表一颗炸弹最多能炸掉地图上目标的总价值数目。

数据范围

0 ≤ R ≤ 10^9
0 < N ≤ 10000
0 ≤ Xi,Yi ≤ 5000
0 ≤ Wi ≤ 1000

输入样例:

2 1
0 0 1
1 1 1

输出样例:

1

思路:

前缀和思路:

由图可以看出:

S [ i ] [ j ] = S [ i − 1 ] [ j ] + S [ i ] [ j − 1 ] − S [ i − 1 ] [ j − 1 ] + A [ i ] [ j ] S[i][j] = S[i-1][j] + S[i][j-1] - S[i-1][j-1] + A[i][j] S[i][j]=S[i1][j]+S[i][j1]S[i1][j1]+A[i][j]

对于任意一个边长 R 正方形:

S = S [ i ] [ j ] − S [ i − R ] [ j ] − S [ i ] [ j − R ] + S [ i − R ] [ j − R ] S = S[i][j] - S[i-R][j] - S[i][j-R] + S[i-R][j-R] S=S[i][j]S[iR][j]S[i][jR]+S[iR][jR]

算法:

import java.util.*;

public class Main {
    
    public static int MAX = 5010;
    public static int[][] s = new int[MAX][MAX];
    public static int N, R;
    
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        N = scanner.nextInt();
        R = scanner.nextInt();
        int x, y, w;
        int xMax = 0, yMax = 0;
        scanner.nextLine();
        for(int i = 0; i < N; i++) {
            String[] str = scanner.nextLine().split(" ");
            x = Integer.parseInt(str[0]);
            y = Integer.parseInt(str[1]);
            w = Integer.parseInt(str[2]);
            x++; y++;
            s[x][y] += w;
            xMax = Math.max(xMax, x);
            yMax = Math.max(yMax, y);
        }
        int ans = 0;
        for(int i = 1; i <= xMax ; i++) {
            for(int j = 1; j <= yMax; j++) {
              	// 这里利用动态规划思路求S
                s[i][j] += s[i - 1][j] + s[i][j - 1] - s[i-1][j-1];
                // 这里利用S求正方形面积。边长不够 R 直接求到左上角的矩形。
                x = i - R >= 0 ? i-R : 0;
                y = j - R >= 0 ? j-R : 0;
                int area = s[i][j] - s[x][j] -s[i][y] + s[x][y];
                ans = Math.max(ans, area);
            }
        }
        System.out.println(ans);
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

每日一题 AcWing 99.激光炸弹 的相关文章

  • pb使用记录 关于pbt、pbr、pbd

    pb使用记录 关于pbl pbt pbr pbd 最近使用pb修改程序 遇到一些基础问题 之前有过了解但是几年没有碰过PB有些忘了 简单记录一下 1 关于pbl pbt pbr pbd pbt powerbuilder target 是8以
  • Java代码的静态编译和动态编译中的问题比较(1)

    Java 应用程序的性能经常成为开发社区中的讨论热点 因为该语言的设计初衷是使用解释的方式支持应用程序的可移植性目标 早期 Java 运行时所提供的性能级别远低于 C 和 C 之类的编译语言 尽管这些语言可以提供更高的性能 但是生成的代码只
  • 一篇文章带你了解JavaScript中的变量,作用域和内存问题

    作者 Jeskson 来源 达达前端小酒馆 1 在JavaScript中的变量分别区分为两种 一种为基本类型值 一种为引用类型值 基本类型值指的是简单的数据段 引用类型值为可能由多个值组成的对象 引用类型的值是保存在内存中的对象 JavaS

随机推荐

  • maven install的时候报Unable to find main class

    目录 问题描述 解决办法 解决方案一 添加一个主函数 解决方案二 将不是web工程的设置跳过 解决方案三 打包插件的作用本质上就是将当前项目所依赖的jar打包到一块 这样jar包就可以运行了 我们完全可以把parent的pom xml的bu
  • tauri使用github进行打包和自动更新教程

    之前的几篇文章介绍了tauri的基本安装 本地打包等方法 本文将接着就前几篇文章进行继续阐述 着重介绍tauri介绍tauri以github为后台服务进行打包 更新 以及tauri配置启动图 一 tauri使用github进行打包 1 首先
  • 学编程买什么电脑最好?

    补充下背景 在编程界 编程设备 电脑 有两个世界 一个是普通世界 这个世界里 程序员写代码的电脑和大众玩游戏看电影上网做ppt的电脑一样 就是你手头的普通电脑 什么电脑都行 另一个世界 是专业世界 是非windows行业的专业 高端 杨村白
  • C++ 学习(11)类和对象、封装、访问权限、成员属性私有性、构造函数与析构函数

    面向对象的特点 封装 继承 多态 万事万物皆为对象 对象上有其属性和行为 方法 1 封装 将属性与行为作为一个整体 表现生活中的事物 将属性和行为加以权限控制 public private等 C 封装 语法 class 类名 访问权限 属性
  • MBIST --- PATR1.Memorybist测试原理

    mem bist作为现在design设计中不可或缺的DFT设计内容 越发重要 本章节主要介绍mem bist组成部分 测试的原理以及注意事项 1 mem bist implementation 1 1 如下图所示为最basic的mbist
  • LeetCode 1476. 子矩形查询

    请你实现一个类 SubrectangleQueries 它的构造函数的参数是一个 rows x cols 的矩形 这里用整数矩阵表示 并支持以下两种操作 updateSubrectangle int row1 int col1 int ro
  • 利用randlanet训练示例semantic3D数据并将预测结果可视化

    1 深度学习环境配置 安装ubuntu 18 安装显卡驱动 cuda cuDNN 安装anaconda 安装tensorflow gpu包 下载randlanet 2 训练semantic3D数据并预测 2 1下载数据 进入RandLA N
  • ajax原理总结,关于Ajax技术原理的3点总结

    ajax Asynchronous Javascript and XML 异步Javascript 和XML 是一种创建交互式网页应用的网页开发技术 1 0 优势 1 1 通过异步模式 提升了用户体验 1 2 优化了浏览器与服务器之间的传输
  • 效率提高80%,Go开发必备的库与工具!

    不知不觉写 Go 已经快一年了 上线了大大小小好几个项目 心态也经历了几轮变化 因为我个人大概前五年时间写的是 Java 中途写过一年多的 Python 所以刚接触到 Go 时的感觉如下图 既没有 Java 的生态 也没有 Python 这
  • 漏写volatile造成的惨案

    之前笔者在做一个基于 Air724UG openmcu CSDK 项目 里面写了如下的代码片段 uint32 t flag 0 void timer handle void para 1秒定时器中断 flag 1 void thread r
  • kettle 入门配置

    1 kettle 介绍 kettle 水壶 是一个 免费开源的 Extract Transform Load ETL 工具 被 Pentaho 集团收购 并更名为 Pentaho Data Integration PDI 当中又包含了四大厨
  • DIY制作并安装JDK8绿色版

    前言 官网提供的JDK8只有安装包 没有绿色免安版 而我们开发时需要根据需求使用不同的JDK版本 使用安装包安装过程会写入注册表 不方便便携式使用 还会附带安装Java 8 Update 会自动更新 而绿色版不会写入注册表 不会自动更新 不
  • HCIA 网络基础

    目录 一 网络概念 二 最初的网络层次 三 网络增大 四 传输介质 1 同轴电缆 2 双绞线 RJ 45 3 光纤 4 无线传输 五 网络增大过程中的升级要求 六 拓扑结构 1 总线型 2 星型 3 环型 4 网状型 七 网桥 gt 交换机
  • 性能测试jmeter连接数据库jdbc(sql server举例)

    一 下载第三方工具包驱动数据库 1 因为JMeter本身没有提供链接数据库的功能 所以我们需要借助第三方的工具包来实现 有这个jar包之后 jmeter可以发起jdbc请求 没有这个jar包 也有jdbc取样器 但不能发起请求 2 进入ma
  • html的marquee标签,marquee 标签参数详细说明

    marquee 元素 可以 用来插入一段滚动的文字 实现类似走马灯的动效 但这个标签已经过时 MDN文档已经不建议使用 此前因之前项目紧急用过 做个标签参数小结 1 marquee的属性 behavior 设置文本如何滚动 属性值有3种 s
  • React生命周期

    React的生命周期 1 挂载卸载过程 constructor componentWillMount componentDidMount componentWillUnmount 2 更新过程 componentWillReceivePro
  • 利用云服务器搭建解锁网易云变灰歌曲的代理

    前言 最近又在GitHub上发现一个有趣的项目 UnblockNeteaseMusic 还是那句话建议在使用前仔细阅读一下项目的readme 于是打算做一个搭建的教程 本文用搭建了宝塔面板的CentOS的服务器做演示 所以文中包含了宝塔面板
  • C语言常量、变量、标识符

    一 变量概述 变量是一个保存数据的地方 当我们需要在程序里保存数据时 就需要一个变量来保存它 变量定义的一般形式就是 lt 类型名称 gt lt 变量名称 gt 例如 int price int amount int price amoun
  • package.json文件中,^和~的区别

    package json文件里面 显示的是项目所依赖的插件和库的名称和版本 和 就是说明版本号的 它将当前库的版本更新到第一个数字 major version 中的最新版本 比如 12 2 2 库会匹配更新到12 X X的最新版本 但是不会
  • 每日一题 AcWing 99.激光炸弹

    题目 地图上有 N 个目标 用整数 Xi Yi 表示目标在地图上的位置 每个目标都有一个价值 Wi 注意 不同目标可能在同一位置 现在有一种新型的激光炸弹 可以摧毁一个包含 R R 个位置的正方形内的所有目标 激光炸弹的投放是通过卫星定位的