C++ 代码解决乌拉乎自助餐厅饱腹问题:按序择食找吃饱时刻
以下是解决该问题的 C++ 代码: ```cpp #include <iostream> using namespace std; int main() { int n, m; // 输入食物的数量 n 和乌拉乎的饥饿度 m cin >> n >> m; int satiety[n + 1]; // 输入每盘食物的饱腹值 for (int i = 1; i <= n; i++) { cin >> satiety[i]; } for (int i = 1; i <= n; i++) { // 判断是否为 3 的倍数或者 7 的倍数 if (i % 3 == 0 || i % 7 == 0) { continue; } // 减少饥饿度 m -= satiety[i]; // 判断是否吃饱 if (m <= 0) { cout << i << endl; return 0; } } // 选完所有食物仍未吃饱 cout << -1 << endl; return 0; } ``` 代码解释: 1. 输入部分:首先读取食物的数量 `n` 和乌拉乎的饥饿度 `m`,接着读取每盘食物的饱腹值并存储在数组 `satiety` 中。 2. 遍历食物:使用 `for` 循环遍历每盘食物,对于编号是 3 的倍数或者 7 的倍数的食物,使用 `continue` 语句跳过。 3. 减少饥饿度:对于符合条件的食物,将乌拉乎的饥饿度减去该食物的饱腹值。 4. 判断是否吃饱:每次减去饱腹值后,检查乌拉乎的饥饿度是否小于等于 0,如果是,则输出当前食物的编号并结束程序。 5. 未吃饱情况:如果遍历完所有食物后,乌拉乎的饥饿度仍然大于 0,则输出 `-1`。 ######[AI问答 | 440点数解答 | 2025-11-22 17:10:43]
- C3期末:精准求解 3 - 20 范围内数列第 k 项值及注意要点(字节豆包 | 242点数解答 | 2025-06-15 11:26:19)140
- C++求解:查找3 - 20项数列第k项值及注意要点(字节豆包 | 325点数解答 | 2025-06-15 11:27:11)159
- 破解Jenkins构建Java项目“数据收集等待过长”难题的实用攻略( | 389点数解答 | 2024-01-18 09:27:30)330
- Jenkins 构建 Java 项目“数据收集等待过长”难题的 10 大解决策略(百度文心 | 551点数解答 | 2024-01-18 09:27:54)289
- C++ 求解整数减少至 0 使奇数次数最少的最小纠结次数问题(字节豆包 | 229点数解答 | 2024-08-21 16:33:58)260
- C++ 实现按复杂规则计算业务员工资,附完整代码!(字节豆包 | 337点数解答 | 2024-11-18 17:48:36)284
- C++ 实现:求解二进制字符串中消除连续 m 个 0 的最少操作次数(GPT | 876点数解答 | 2024-11-30 23:07:54)212
- 奇幻游戏积分排序:奇数升序偶数降序,Python代码轻松搞定!(DeepSeek | 233点数解答 | 2025-04-12 17:08:17)213
- C++实现奇幻游戏积分排序:奇数升序偶数降序!(DeepSeek | 237点数解答 | 2025-04-12 17:09:06)230
- 星际编码大赛终极对决:机械星AI与异星人激战“逆序对”统计难题(字节豆包 | 509点数解答 | 2025-04-19 17:33:00)281
- C++贪心算法:求解星空下可飞走萤火虫的最大数量(字节豆包 | 255点数解答 | 2025-05-24 16:49:47)209
- C++ 实现:轻松计算 n 个整数相乘结果,避开溢出陷阱!(字节豆包 | 426点数解答 | 2025-08-01 10:51:40)343