博客
关于我
99. 激光炸弹(前缀和)
阅读量:803 次
发布时间:2023-04-17

本文共 1617 字,大约阅读时间需要 5 分钟。

为了解决这个问题,我们需要找到一种方法来确定炸弹的最大炸击价值。炸弹的范围是一个正方形,边长为r,且只有严格在正方形内部的宝物才会被炸掉。我们可以使用前缀和的思想来快速计算特定矩形区域内的宝物总价值,从而高效地解决这个问题。

方法思路

  • 前缀和矩阵构建:我们使用一个二维前缀和矩阵来存储从原点(0,0)到每个点(i-1, j-1)的所有宝物的总价值。这样,任意矩形区域内的宝物总价值可以在O(1)的时间内计算出来。
  • 输入处理:读取输入数据,构建前缀和矩阵。由于宝物的位置可能重复,我们在读取数据时累加这些值。
  • 前缀和矩阵计算:根据前缀和的定义,逐步计算每个点的前缀和值。
  • 炸弹范围遍历:枚举所有可能的炸弹位置,计算每个位置能炸掉的宝物价值。炸弹的范围是(r-1)x(r-1)的正方形,我们需要确保这个正方形完全在网格内。
  • 解决代码

    #include 
    using namespace std;
    int main() {
    int n, r;
    cin >> n >> r;
    r = min(r, 5002); // 限制r的最大值为5002
    int s[5003][5003]; // 初始化前缀和矩阵
    for (int i = 1; i <= n; ++i) {
    for (int j = 1; j <= n; ++j) {
    int x, y, w;
    cin >> x >> y >> w;
    s[x + 1][y + 1] += w; // 为了避免越界,使用x+1, y+1
    }
    }
    // 构建前缀和矩阵
    for (int i = 1; i <= 5002; ++i) {
    for (int j = 1; j <= 5002; ++j) {
    s[i][j] += s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1];
    }
    }
    int max_value = 0;
    // 遍历所有可能的r-1范围的位置
    for (int i = r; i <= 5002; ++i) {
    for (int j = r; j <= 5002; ++j) {
    int left = i - r + 1;
    int top = j - r + 1;
    if (left < 1 || top < 1) {
    continue; // 越界情况,无法形成有效的正方形
    }
    int current = s[i][j] - s[left - 1][j] - s[i][top - 1] + s[left - 1][top - 1];
    if (current > max_value) {
    max_value = current;
    }
    }
    }
    cout << max_value;
    }

    代码解释

  • 输入处理:读取输入数据,构建前缀和矩阵。每个宝物的位置(x, y)和价值w被读取并累加到对应的前缀和位置。
  • 前缀和矩阵计算:使用双重循环计算前缀和矩阵,确保每个点的前缀和值正确。
  • 炸弹范围遍历:枚举所有可能的炸弹位置,计算每个位置能炸掉的宝物价值。使用前缀和矩阵快速计算特定矩形区域的和,确保找到最大价值。
  • 这种方法利用了前缀和的思想,确保了计算的高效性,能够在大规模数据下快速解决问题。

    转载地址:http://sagfk.baihongyu.com/

    你可能感兴趣的文章
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>
    MySQL 快速创建千万级测试数据
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    MySql 手动执行主从备份
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>
    mysql 数据库存储引擎怎么选择?快来看看性能测试吧
    查看>>
    MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
    查看>>
    MySQL 数据库的高可用性分析
    查看>>