首页 > 其他分享 >18118 勇者斗恶龙

18118 勇者斗恶龙

时间:2024-08-21 17:25:44浏览次数:14  
标签:int dragonHeads 花费 ++ 勇者 knights 恶龙 骑士 18118

### 详细分析

为了最小化雇佣骑士的花费,我们可以使用贪心算法。具体步骤如下:

1. **排序**:将恶龙的头直径和骑士的能力值分别排序。
2. **匹配**:从最小的头开始,找到第一个能够砍掉这个头的骑士,并记录花费。继续匹配下一个头,直到所有头都被砍掉或没有合适的骑士为止。
3. **判断**:如果所有头都被砍掉,输出总花费;否则输出"Loowater is doomed!"。

### 伪代码

1. 读取输入的 `n` 和 `m`。
2. 如果 `n` 和 `m` 都为 0,结束输入。
3. 读取 `n` 个恶龙头的直径。
4. 读取 `m` 个骑士的能力值。
5. 对恶龙头的直径和骑士的能力值进行排序。
6. 初始化两个指针 `i` 和 `j` 分别指向恶龙头和骑士的起始位置,初始化总花费 `cost` 为 0。
7. 遍历恶龙头:
   - 如果当前骑士的能力值大于等于当前恶龙头的直径,匹配成功,更新总花费,移动两个指针。
   - 否则,移动骑士指针。
8. 如果所有恶龙头都被匹配,输出总花费;否则输出"Loowater is doomed!".

### C++代码

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

using namespace std;

int main() {
    while (true) {
        int n, m;
        cin >> n >> m;
        if (n == 0 && m == 0) break;

        vector<int> dragonHeads(n);
        vector<int> knights(m);

        for (int i = 0; i < n; ++i) {
            cin >> dragonHeads[i];
        }
        for (int i = 0; i < m; ++i) {
            cin >> knights[i];
        }

        sort(dragonHeads.begin(), dragonHeads.end());
        sort(knights.begin(), knights.end());

        int cost = 0;
        int i = 0, j = 0;

        while (i < n && j < m) {
            if (knights[j] >= dragonHeads[i]) {
                cost += knights[j];
                ++i;
            }
            ++j;
        }

        if (i == n) {
            cout << cost << endl;
        } else {
            cout << "Loowater is doomed!" << endl;
        }
    }

    return 0;
}


 

标签:int,dragonHeads,花费,++,勇者,knights,恶龙,骑士,18118
From: https://blog.csdn.net/huang1xiao1sheng/article/details/141337042

相关文章

  • 骑行无界,勇者无限!2024COSP上海国际户外展带您畅享生活的速度与激情!
    随着夏日来临,越来越多的人选择借由“绿色骑行”去触碰一座城市的脉搏,“城市骑行”正在成为时尚潮流活动和生活休闲方式。对于一部分城市打工人来说,自行车是一种通勤的工具,骑行成为健身的新选择。在小红书里输入“骑行”,大约有280万+笔记,“骑行路线”“骑行装备”“骑行穿搭”......
  • 2024-04-17:用go语言,欢迎各位勇者莅临力扣城,本次的挑战游戏名为「力扣泡泡龙」。 游戏
    2024-04-17:用go语言,欢迎各位勇者莅临力扣城,本次的挑战游戏名为「力扣泡泡龙」。游戏的起点是一颗形状如二叉树的泡泡树,其中每个节点的值代表该泡泡的分值。勇者们有一次机会可以击破一个节点泡泡,但需要满足以下规则:被击破的节点泡泡最多只能有一个子节点泡泡。如果被击破的节点......
  • 屠龙少年终成恶龙,前端转产品的我给前端挖了个坑
    屠龙少年终成恶龙,前端转产品的我给前端挖了个坑前端转产品3周左右,把自己的一些感受通过《我转产品了-前端转产品是一种什么样的体验》这篇文章与大家分享,评论区惊现一波大佬。由于比较忙,不知不觉好像转眼间已经又过去一个多月,这次趁着周末没有开成会,给大家分享一下最近的『趣事』......
  • 完整的交易系统!-------知者不惑,仁者不忧,勇者不惧
    本文转自网络。来源:《海归交易法则》。感兴趣的朋友可购买正版图书进行更深入研究。◎柯蒂斯费恩著 ◎乔江涛译 完整的交易系统 大多数成功的交易者都使用机械......
  • 47. 【大学】北理工的恶龙
    47.【大学】北理工的恶龙 背景:最近,北理工出现了一只恶龙,它长着很多头,而且还会吐火,它将会把北理工烧成废墟,于是,校长下令召集全校所有勇士杀死这只恶龙。要杀死这只......
  • 2022年春秋杯春季-勇者山峰-部分WriteUp
    关注公众号看图弹钢琴得到flag2、Mercy-code<?phphighlight_file(__FILE__);if($_POST['cmd']){$cmd=$_POST['cmd'];if(';'===preg_replace('/[a-z_]+\((?......
  • 23.孤勇者
    都是勇敢的你额头的伤口你的不同你犯的错都不必隐藏你破旧的玩偶你的面具你的自我他们说要带着光驯服每一头怪兽他们说要缝好你的伤没有人爱小丑为何孤......