你拥有对数字实施魔法的能力,有一天,你接到了一个任务。需要施展魔法,将正整数 a 变成正整数 b。你决定使用以下三种魔法,每一种魔法均可施展任意次: 1. 删除数a的个位,即a=a/10; 2. 在数a的末尾增加一个0,即a=a*10; 3. 将数a的个位修改为另一个数。 每施展一次魔法,均需消耗 K 单位能量。现想要知道,完成该任务,你最少消耗多少单位能量。 输入格式 输入共三行,依次为三个正整数 a, b, k。 输出格式 输出一个整数,代表最少消耗多少单位能量。 用C++
```cpp #include <iostream> #include <queue> #include <unordered_set> #include <climits> using namespace std; // 自定义结构体用于存储当前的数字和消耗的能量 struct Node { long long num; int energy; Node(long long n, int e) : num(n), energy(e) {} }; // 广度优先搜索函数,用于寻找最少消耗的能量 int bfs(long long a, long long b, int k) { queue<Node> q; unordered_set<long long> visited; // 将起始数字和消耗能量为0的节点加入队列 q.push(Node(a, 0)); visited.insert(a); while (!q.empty()) { Node current = q.front(); q.pop(); // 如果当前数字等于目标数字,返回消耗的能量 if (current.num == b) { return current.energy; } // 魔法1:删除数a的个位 if (current.num > 10) { long long newNum = current.num / 10; if (visited.find(newNum) == visited.end()) { q.push(Node(newNum, current.energy + k)); visited.insert(newNum); } } // 魔法2:在数a的末尾增加一个0 long long newNum2 = current.num * 10; if (visited.find(newNum2) == visited.end()) { q.push(Node(newNum2, current.energy + k)); visited.insert(newNum2); } // 魔法3:将数a的个位修改为另一个数 long long base = current.num / 10 * 10; for (int i = 0; i < 10; i++) { long long newNum3 = base + i; if (newNum3 > 0 && visited.find(newNum3) == visited.end()) { q.push(Node(newNum3, current.energy + k)); visited.insert(newNum3); } } } return -1; // 无法完成任务 } int main() { long long a, b; int k; // 读取输入 cin >> a >> b >> k; // 调用广度优先搜索函数 int result = bfs(a, b, k); cout << result << endl; return 0; } ``` 代码 1. 定义了一个结构体 `Node` 用于存储当前的数字和消耗的能量。 2. `bfs` 函数实现了广度优先搜索算法,使用队列和哈希集合来记录已访问的数字。 3. 在 `bfs` 函数中,分别实现了三种魔法操作,并将新生成的数字加入队列。 4. 如果找到目标数字,返回消耗的能量;如果队列为空仍未找到,返回 -1 表示无法完成任务。 5. `main` 函数读取输入,并调用 `bfs` 函数,最后输出结果。 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 要注意数字可能会超出 `int` 类型的范围,因此使用 `long long` 类型来存储数字。 2. 在进行魔法操作时,要确保生成的新数字是正整数,避免出现非法数字。 3. 哈希集合的使用可以避免重复访问相同的数字,但是要注意插入和查找操作的性能,尤其是在处理大量数据时。 [2025-11-23 20:49:59 | AI写代码神器 | 812点数解答]
- [字节豆包] 题目描述 午饭时间,喵喵喵幼儿园的n位小朋友从左到右排成一列等待领取自己的午餐。我们 将这些小朋友从左到右依次标号为 1,2,⋯,n−1,n。 负责配餐的老师已经拿到了所有人的午饭餐食,餐食同样也是从左到右排成一排。 老师手里拿到了一份序列 r1 ⋯rn,代表编号为i的小朋友应该拿到从左向右数第 ri份 午餐餐食(1≤ri≤n且 ri两两不同)。 按照上面的序列分发完成后,老师又拿到了一个序列 a1⋯an,其中 a i代表未分发前从 左向右数第 i 份餐食的一个参数。 老师想要知道,对每个小朋友,他们所拿到的午餐的这个参数的值是多少。但是这个 任务对于老师来说太难了,所以喵喵喵幼儿园找到了万能的你。 输入格式 共三行。 第一行一个整数,代表 n。 第二行 n 个整数,代表 r1⋯rn。 第三行 n 个整数,代表 a1⋯an。 输出格式 一行,n 个整数。第 i 个整数代表编号为 i 的小朋友所拿到的午餐的这个参数是多 少。 输入输出样例 输入 #1 4 4 1 3 2 7 4 2 9 输出 #1 9 7 2 4 说明/提示 样例解释 编号(481点数解答 | 2025-11-16 19:24:11)22
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(385点数解答 | 2025-01-08 03:43:54)362
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(346点数解答 | 2025-01-08 03:46:29)361
- [字节豆包] pandas读取文件,文件某一列分组,条件为列数据字段中包含“一级”为一组,没有“一级”的为一组,将pandas读取到的文件按地市映射表分为各地市文件,再将这个文件当作邮件附件,邮件正文为某地市,有“一级”多少,没有“一级”多少,语言方向:Python,系统环境:Windows(459点数解答 | 2024-12-25 01:17:06)211
- [字节豆包] 读入数据文件 data.xlsx,实现以下功能: # 数据做字符串处理dtype=str df = pd.read_excel(r'd:\data.xlsx', dtype=str) 1、将列名'商品编码'改为'药品编码',将列名'商品名称'改为'药品名称' (rename()方法实现重新标记行索引或列名,通常使用原索引与新索引(原列名与新列名)组成的字典作为参数。 例如:df=df.rename(columns={'name':'姓名','class':'班级'})) 2、对缺失数据做删除处理(查询哪些字段和记录有空值,并显示社保卡号为空值的记录,并删除有空值的记录) 3、将'销售数量'的数据类型转换为整型'int',将'应收金额'和'实收金额'的数据类型转换为浮点型'float' 4、将'购药时间'截取前面的日期字符串,并将该字段转化为时间类型 (截取字符串可以使用代码:df['购药时间'] = df['购药时间'].map(lambda x: x.split()[0])) 5、删除‘销售数量’小于等于0的数据。(查看数据框信息,看看删除后记录的改变) 6(168点数解答 | 2025-04-17 16:51:27)203
- [字节豆包] 实验一、DES加密算法编程实验 ────────────────────────────────── 一、实验目标 理解 DES 的整体结构:Feistel 网络、16 轮迭代、子密钥生成。 掌握 DES 核心部件的编程实现:IP / IP⁻¹、E-扩展、S-盒、P-置换、PC-1 / PC-2、左右移位。 熟悉分组密码工作模式与填充方式:本实验采用「每 64 bit 一块 + PKCS5 填充」。 通过加/解密验证程序正确性,并能对单步结果进行人工比对。 ────────────────────────────────── 二、实验环境 • 语言:Python 3.8+(仅标准库 + binascii)。 • 编辑器:VS Code / PyCharm / Jupyter Notebook 均可。 • 操作系统:Windows / macOS / Linux 不限。 • 额外工具: – 十六进制查看器(HxD、xxd) – 在线 DES 计算器(验证用) ────────────────────────────────── 三、实验任务与步骤 任务 1:单步调试与日志分析 在 des(4096点数解答 | 2025-11-09 22:06:30)27
- [阿里通义] 一个 5×6 的迷宫样例如下: 要求给出从起点(1,1)到终点(3,4)的路径。 为了处理方便,保证最外圈全都为障碍物。 扩展到一般情况,一个 m×n 的迷宫,要求输出从起点(1,1)到终点(m-2,n-2)的路径。 测试实例保证路径是唯一的。 该题要求自行设计一个栈来做。如果设计的是顺序栈,则保证栈的大小不超过 200 个元素。 输入 第一行为两个整数 m 和 n,表示 m×n 的迷宫。 接下来有 m 行,每行有 n 个数(n 个数之间用空格间隔,值 = 0 表示可以通行,值 = 1 表示为障碍物) 输出 输出从起点到终点的路径,每个坐标占一行,坐标间的行号和列号用一个空格间隔。具体格式可参考样例。c++ 源代码(732点数解答 | 2024-11-03 02:34:53)442
- [字节豆包] 开学了,小明来到文具店选购文具。签字笔 2 2 元一支,他需要 X X 支;记事本 5 5 元一本,他需要 Y Y 本;直尺 3 3 元一把,他需要 Z Z 把。小明手里有 Q Q 元钱。请你通过编程帮小明算算,他手里的钱是否够买他需要的文具。 输入格式 第一行包含一个正整数,是小明购买签字笔的数量。约定 1 ≤ X ≤ 10 1≤X≤10。 第二行包含一个正整数,是小明购买记事本的数量。约定 1 ≤ Y ≤ 10 1≤Y≤10。 第三行包含一个正整数,是小明购买直尺的数量。约定 1 ≤ Z ≤ 10 1≤Z≤10。 第四行包含一个正整数 Q Q,是小明手里的钱数(单位:元)。 输出格式 输出 2 2 行。如果小明手里的钱够买他需要的文具,则第一行输出 Yes,第二行输出小明会剩下的钱数(单位:元);否则,第一行输出 No,第二行输出小明缺少的钱数(单位:元)。(256点数解答 | 2025-10-25 22:28:48)43
- [字节豆包] c++ 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号)(320点数解答 | 2025-11-28 19:40:52)12
- [字节豆包] c++ 小核桃破解了大门的密码,门上开始显示一个进度条。请你帮助小核桃补全代码,输入n,如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。 输入: 一个整数n(0<=n<=100)。 输出: 如果n是10的倍数,输出n%;再判断如果n是100,额外输出"完成!"。(注意,感叹号为英文感叹号) (338点数解答 | 2025-11-28 19:42:04)12
- [百度文心] c++描述 小夏同学在思考一个复杂的问题: 输入 m,a,n,请输出 ( i=1 ∑ n a i )modm,即 (a+a 2 +⋯+a n )modm。 说明/提示 对于所有测试数据,保证:1≤m,a≤10 9 ,1≤n≤10 15 。 测试点编号 n a 特殊性质 1−3 ≤10 7 ≤10 9 无 4−6 ≤10 15 ≤2 无 7−10 ≤10 15 ≤10 9 m 为质数 11−20 ≤10 15 ≤10 9 无 输入描述 输入 m,a,n。 输出描述 输出 ( i=1 ∑ n a i )modm。 用例输入 1 1000 2 10 用例输出 1 46 用例输入 2 11451410 1919811 8765423561347 用例输出 2 2213137 用例输入 3 114514 9999 1000 用例输出 3 28840(911点数解答 | 2025-03-29 19:12:07)251
- [阿里通义] 使用c语言贪心法完成下列问题的算法设计与代码编写 (1)多机调度问题 第一行输入 任务数量 7 第二行输入 任务处理时间 2 14 4 16 6 5 3 第三行输入 机器数量 3 输出 机器编号 任务 输出格式为: 机器编号 任务 0 4 1 2 2 5 2 6 2 3 1 7 2 1(665点数解答 | 2024-11-27 08:39:39)287