news 2026/5/10 8:24:33

GESP认证C++编程真题解析 | B3866 [GESP202309 二级] 数字黑洞

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | B3866 [GESP202309 二级] 数字黑洞

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[B3866 GESP202309 二级] 数字黑洞 - 洛谷

【题目描述】

给定一个三位数,要求各位不能相同。例如,352 352352是符合要求的,112 112112是不符合要求的。将这个三位数的三个数字重新排列,得到的最大的数,减去得到的最小的数,形成一个新的三位数。对这个新的三位数可以重复上述过程。神奇的是,最终一定会得到495 495495

试试看,重新排列352 352352,得到的最大数为532 532532,最小数为235 235235,它们的差是297 297297;变换297 297297,得到972 − 279 = 693 972-279=693972279=693;变换693 693693963 − 369 = 594 963-369=594963369=594;变换594 594594954 − 459 = 495 954-459=495954459=495。因此,经过4 44次变换得到了495 495495

现在,输入的三位数,你能通过编程得出,这个三位数经过多少次变换能够得到495 495495吗?

【输入】

输入一行,包含一个符合要求的三位数N NN

【输出】

输出一行,包含一个整数C CC,表示经过C CC次变换得到495 495495

【输入样例】

352

【输出样例】

4

【算法标签】

《洛谷 B3866 数字黑洞》 #GESP# #2023#

【代码详解】

#include<iostream>#include<algorithm>usingnamespacestd;intmain(){intn;cin>>n;// 检查输入范围if(n<100||n>999){cout<<"请输入三位数"<<endl;return0;}// 检查是否全相同inta=n/100,b=(n/10)%10,c=n%10;if(a==b&&b==c){cout<<"数字全相同,不会收敛"<<endl;return0;}intsteps=0;while(n!=495){// 分解数字intdigits[3];digits[0]=n/100;// 百位digits[1]=(n/10)%10;// 十位digits[2]=n%10;// 个位// 升序排序得最小数sort(digits,digits+3);intmin_num=digits[0]*100+digits[1]*10+digits[2];// 降序排序得最大数sort(digits,digits+3,greater<int>());intmax_num=digits[0]*100+digits[1]*10+digits[2];// 计算差值n=max_num-min_num;steps++;// 安全限制,防止死循环if(steps>100){cout<<"可能陷入循环"<<endl;return0;}}cout<<steps<<endl;return0;}

【运行结果】

352 4
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 8:24:30

【Java毕设全套源码+文档】基于springboot的网购商城管理系统设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/1 10:33:20

【Java毕设全套源码+文档】基于springboot的宠物猫售卖管理系统设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/5 0:27:11

AI有声书制作新方式:EmotiVoice自动朗读带情绪

AI有声书制作新方式&#xff1a;EmotiVoice自动朗读带情绪 在有声内容消费日益增长的今天&#xff0c;用户早已不再满足于“能听”的机械朗读。无论是通勤路上收听小说&#xff0c;还是孩子睡前聆听童话故事&#xff0c;听众期待的是富有情感、角色分明、沉浸感强的声音演绎。…

作者头像 李华
网站建设 2026/5/6 18:02:13

jQuery EasyUI 应用 - 创建 CRUD 应用

jQuery EasyUI 应用 - 创建 CRUD 应用 数据收集并妥善管理数据是网络应用常见的必要功能。CRUD&#xff08;Create 创建、Read 读取、Update 更新、Delete 删除&#xff09;允许我们生成页面来列表显示并编辑数据库记录。本教程将演示如何使用 jQuery EasyUI 框架实现一个基本…

作者头像 李华
网站建设 2026/5/8 12:49:58

jQuery EasyUI 拖放 - 创建拖放的购物车

jQuery EasyUI 拖放 - 创建拖放的购物车 使用 jQuery EasyUI 的 draggable 和 droppable 插件&#xff0c;可以轻松实现一个交互式的拖放购物车应用。用户可以将商品图片拖动到购物车区域&#xff0c;系统自动添加商品、更新数量&#xff08;重复拖动时增加数量&#xff09;和…

作者头像 李华