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. 遍历恶龙头:

  • 如果当前骑士的能力值大于等于当前恶龙头的直径,匹配成功,更新总花费,移动两个指针。

  • 否则,移动骑士指针。

  1. 如果所有恶龙头都被匹配,输出总花费;否则输出"Loowater is doomed!".

C++代码

cpp 复制代码
#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;
}
相关推荐
巨人张2 分钟前
C++零基础游戏----“大鱼吃小鱼”
java·c++·游戏
无尽的罚坐人生3 分钟前
hot 100 128. 最长连续序列
数据结构·算法·贪心算法
Savior`L5 分钟前
基础算法:模拟、枚举
数据结构·c++·算法
软件算法开发15 分钟前
基于蘑菇繁殖优化的LSTM深度学习网络模型(MRO-LSTM)的一维时间序列预测算法matlab仿真
深度学习·算法·matlab·lstm·时间序列预测·蘑菇繁殖优化·mro-lstm
雪花desu16 分钟前
【Hot100-Java中等】LeetCode 11. 盛最多水的容器:双指针法的直观理解与数学证明
算法·leetcode
POLITE317 分钟前
Leetcode 438. 找到字符串中所有字母异位词 JavaScript (Day 4)
javascript·算法·leetcode
汉克老师18 分钟前
GESP2025年12月认证C++一级真题与解析(判断题1-10)
c++·gesp一级·gesp1级
海绵宝龙22 分钟前
Vue 中的 Diff 算法
前端·vue.js·算法
_Voosk25 分钟前
macOS Xcode C++程序设置相对路径根目录
c语言·c++·xcode·swift
wadesir37 分钟前
高效计算欧拉函数(Rust语言实现详解)
开发语言·算法·rust