B3628 机器猫斗恶龙

题目描述

机器猫出门斗恶龙了!他需要通过 𝑛 个关卡。

每个关卡要么是与怪物战斗,扣除一定的血量;要么是营地,给机器猫增加一定的血量。

在旅途中,机器猫任意时刻的血量不能低于或等于 0。问机器猫至少需要多少的初始血量,才能完成任务。

血量为正整数。

输入格式

第一行,一个正整数 𝑛n,表示关卡数量。

第二行,共 𝑛n 个整数 𝑎𝑖ai​,表示每个关卡。

  • 若 𝑎𝑖>0,则表示这个关卡是营地,增加 𝑎𝑖 的血量
  • 若 𝑎𝑖<0,则表示这个关卡是战斗,机器猫血量代价为 𝑎𝑖

输出格式

仅一行,一个正整数,表示机器猫需要的初始血量。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int n, a[100005];

void input() {
    cin >> n;
    for(int i = 1; i <= n; i++)
        cin >> a[i]; // a[i] 是血的变化量
}

bool check(int x) { // 计算 x 点血是否可以活下来
    int hp = x;
    for(int i = 1; i <= n; i++){
        hp += a[i]; // hp增加或者减少
        if(hp <= 0) return false; // 如果活不下来返回 false
    }
    return true; // 如果可以活下来,返回 true
}
void work() {
    int l = 1, r = 1000 * 100000, mid;
    int ans = r;
    while(l <= r) {
        mid = (l + r) / 2;
        if(check(mid)) {  // 检查mid血,发现可以活下来
            ans = mid; // 记录下答案
            r = mid - 1; // 继续找左区间
        } else           // 如果发现活不下来
            l = mid + 1; // 继续找右区间
    }
    cout << ans << endl;
}

int main() {
    input();
    work();

    return 0;
}
相关推荐
kingmax542120082 小时前
【洛谷P9303题解】AC- [CCC 2023 J5] CCC Word Hunt
数据结构·c++·算法·广度优先
白熊1882 小时前
【机器学习基础】机器学习入门核心算法:XGBoost 和 LightGBM
人工智能·算法·机器学习
bai_lan_ya3 小时前
数据结构-排序-排序的七种算法(2)
数据结构·算法·排序算法
全域智图4 小时前
元胞自动机(Cellular Automata, CA)
人工智能·算法·机器学习
珂朵莉MM4 小时前
2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家
人工智能·算法·职场和发展·深度优先·图论
独家回忆3644 小时前
每日算法-250601
数据结构·算法
YONYON-R&D4 小时前
DEEPSEEK帮写的STM32消息流函数,直接可用.已经测试
算法·消息流
AgilityBaby5 小时前
UE5打包项目设置Project Settings(打包widows exe安装包)
c++·3d·ue5·游戏引擎·unreal engine
Steve lu6 小时前
回归任务损失函数对比曲线
人工智能·pytorch·深度学习·神经网络·算法·回归·原力计划
蒙奇D索大6 小时前
【数据结构】图论核心算法解析:深度优先搜索(DFS)的纵深遍历与生成树实战指南
数据结构·算法·深度优先·图论·图搜索算法