当前位置: 首页 > article >正文

19050 牛牛打气球

### 思路

1. **输入读取**:
   - 读取 `n`,`a` 和 `b`。
   - 读取每个气球的坚韧度。

2. **计算最少释放次数**:
   - 使用二分查找来确定最少的释放次数。
   - 每次释放武器时,选择一个气球多承受 `a` 点伤害,其他气球承受 `b` 点伤害。
   - 判断在给定次数内是否可以将所有气球的坚韧度降为0。

### 伪代码

1. 读取 `n`,`a`,`b` 和气球坚韧度数组 `durability`。
2. 定义二分查找的左右边界 `left` 和 `right`。
3. 在二分查找的过程中:
   - 计算中间值 `mid`。
   - 初始化 `total_damage` 为 0。
   - 遍历每个气球,计算需要的额外伤害次数。
   - 如果 `total_damage` 小于等于 `mid`,则更新右边界,否则更新左边界。
4. 输出最少的释放次数。

### C++代码
 

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

bool canDestroyAllBalloons(const vector<long long>& durability, long long n, long long a, long long b, long long mid) {
    long long total_damage = 0;
    for (long long i = 0; i < n; ++i) {
        long long required_damage = durability[i] - mid * b;
        if (required_damage > 0) {
            total_damage += (required_damage + a - 1) / a;
        }
        if (total_damage > mid) {
            return false;
        }
    }
    return true;
}

int main() {
    long long n, a, b;
    cin >> n >> a >> b;
    vector<long long> durability(n);
    for (long long i = 0; i < n; ++i) {
        cin >> durability[i];
    }

    long long left = 0, right = *max_element(durability.begin(), durability.end()) / b + 1;
    while (left < right) {
        long long mid = (left + right) / 2;
        if (canDestroyAllBalloons(durability, n, a, b, mid)) {
            right = mid;
        } else {
            left = mid + 1;
        }
    }

    cout << left << endl;
    return 0;
}


http://www.kler.cn/news/283749.html

相关文章:

  • Training language models to follow instructionswith human feedback
  • 【iOS】iOS中简单的网络请求
  • Openai api via azure error: NotFoundError: 404 Resource not found
  • 优化系统性能:深入探讨Web层缓存与Redis应用的挑战与对策
  • 虹科技术|全新Linux环境PCAN驱动程序发布!CAN/CAN FD通信体验全面升级!
  • C# 什么是属性
  • Linux操作系统在虚拟机VM上的安装【CentOS版本】
  • 深入解析 Maven 子父模块的依赖管理
  • Java 面试题:HTTP版本演变--xunznux
  • Web-gpt
  • UR5e Gazebo仿真
  • Go 服务调试精解
  • 备战秋招60天算法挑战,Day28
  • 个人旅游网(1)——数据库表详解
  • 爬虫入门学习
  • Java Web —— 第十天(AOP切面编程)
  • Dxf文件中多段线弧线的计算
  • 三星与海力士发力决战HBM4
  • 【知识】缓存类型和策略
  • 数据合规性分析:守护信息安全的关键防线
  • 原生开发柱状图
  • 钉钉好用吗?类似钉钉的内部知识库有哪些?
  • 【微信小程序】微信小程序如何使用 MobX 进行状态管理?
  • 【已解决】win11笔记本电脑突然无法检测到其他显示器 / 无法使用扩展屏(2024.8.29 / 驱动更新问题)
  • Linux使用ifconfig配置临时ip地址
  • ET6框架(八)事件系统
  • UE5 摄像机图像采集到材质 映射到 UI 和 物体表面
  • C语言内存操作函数
  • gitee版本控制
  • 记录|如何全局监听鼠标和键盘等事件