news 2026/5/26 8:35:06

用贪心算法解决仅含 6 和 9 数字的最大翻转值问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
用贪心算法解决仅含 6 和 9 数字的最大翻转值问题

一,创作灵感

作为一名在校大学生,平时的算法学习中总觉得抽象的算法概念很难落地,直到遇到这个仅由 6 和 9 组成的数字翻转问题。起初我还在纠结要不要枚举所有翻转情况再找最大值,但转念一想,枚举的方式不仅麻烦,效率也不高。后来联想到课堂上学过的贪心算法 —— 每一步都选当下最优解,这不正好契合 “让数字最大” 的核心需求吗?想着把这个解题思路梳理清楚,既巩固课堂上学到的贪心算法知识,也能记录自己从 “无思路” 到 “找方法” 再到 “写代码” 的完整过程,给同样在算法学习中摸索的同学提供一点参考,于是就有了这篇学习笔记。

二、问题场景与需求

在算法作业和刷题过程中,遇到了这样一个有趣的题目:给定一个仅由数字 6 和 9 组成的正整数num,最多只能翻转一位数字(6 变 9 或者 9 变 6),需要找出通过这个操作能得到的最大数字。比如输入9669,要通过合理翻转得到最大的9969。这个问题看似简单,但需要找到最关键的翻转位置,才能高效得到最优解。

三、解题思路 —— 贪心算法

(一)算法选择依据

作为学生,刚开始接触这类问题时,第一反应是 “把所有可能的翻转结果列出来,再找最大值”,但很快发现这种枚举法对于位数多的数字来说效率太低。回忆课堂上老师讲的贪心算法,其核心是 “每一步都做局部最优选择,最终达到全局最优”。对于数字来说,高位的数值变化对整体大小影响远大于低位,所以只要从高位到低位找到第一个能让数字变大的机会(把 6 换成 9),就能得到最大值,这正是贪心算法的典型应用场景。

(二)具体实现步骤
  1. 类型转换:利用 C++ 中的to_string函数把整数num转换成字符串s。因为字符串可以像数组一样通过索引访问每一位字符,相比直接操作整数的每一位(需要取模、除法),这种方式更直观,也符合我们学生日常处理字符类问题的习惯。例如num = 9669,转换后s = "9669"
  2. 遍历替换:从字符串的第 0 位(最高位)开始遍历,一旦遇到字符'6',就把它替换成'9',然后立即用break跳出循环。这是因为只需要翻转一位,且高位的 6 变成 9 能让数值增大最多,找到第一个就完成了最优翻转,无需继续遍历。比如遍历"9669"时,第二位(索引 1)是'6',替换后变为"9969"
  3. 结果还原:用stoi函数把修改后的字符串转回整数,得到最终结果。比如"9969"转换后就是整数9969

四,代码实现(C++)

class Solution { public: int maximum69Number (int num) { string s = to_string(num); // 整数转字符串,方便按位处理 for (int i = 0; i < s.size(); ++i) { // 从高位到低位遍历每一位 if (s[i] == '6') { // 找到第一个能增大数值的6 s[i] = '9'; // 替换为9,实现局部最优 break; // 仅翻转一位,完成后退出循环 } } return stoi(s); // 字符串转回整数返回 } };

五,代码解析

  • to_string函数:作为学生,在处理数字逐位操作时,最容易想到的就是把数字转成字符串,这个函数能快速实现整数到字符串的转换,避免了手动通过取模(%)和除法(/)拆分数字的繁琐,降低了代码的复杂度。
  • 循环遍历逻辑:循环从索引 0 开始,保证优先处理高位,这是贪心算法 “局部最优” 的核心体现。找到第一个'6'就替换并跳出循环,时间复杂度为O(n)n为数字的位数),在学生刷题的场景中,这种线性时间复杂度的解法能高效通过所有测试用例。
  • stoi函数:将修改后的字符串转回整数,满足题目返回整数的要求,完成从 “字符操作” 到 “数值结果” 的闭环,是 C++ 中处理字符串与整数转换的常用方法,也是我们日常编程需要掌握的基础知识点。
  • 六,总结:算法思维,赋能职场认知
  • 从 “数字翻转” 到职场实践,贪心算法的核心逻辑,能帮我们更清晰地做决策、推进工作。但要注意:职场比算法题复杂,需结合业务本质动态调整,既要学会像找 “6” 一样抓核心,也要避免陷入 “局部最优” 忽略全局。

    把算法思维迁移到职场,不是生搬硬套代码逻辑,而是借鉴其 “简化问题、抓住本质” 的思路。愿我们都能在职场的 “数字串” 里,精准找到该翻转的 “6”,用高效决策和聚焦行动,拿到属于自己的 “最大结果”。

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

实体状态和动画的同步

SynchedEntityData 详解 - Minecraft 状态与动画同步的核心机制 一、SynchedEntityData 系统整体架构 1. 系统定位 SynchedEntityData 是 Minecraft 中服务器与客户端数据同步的核心系统,负责在多人游戏中保持实体状态的一致性。这是连接服务器AI逻辑和客户端动画渲染的桥梁…

作者头像 李华
网站建设 2026/5/25 23:42:17

利用cpolar告别局域网束缚!DbGate 让数据库管理随时随地随心

文章目录前言通过 DbGate 与内网穿透的配合&#xff0c;数据库管理变得灵活高效&#xff0c;打破了空间限制&#xff0c;让工作更自由。前言 DbGate 是一款覆盖多种数据库类型的管理工具&#xff0c;无论是关系型的 MySQL&#xff0c;还是 NoSQL 的 MongoDB、Redis 等都能轻松…

作者头像 李华
网站建设 2026/5/26 5:53:32

OpenSpec标准兼容性分析:Qwen3-VL-30B是否符合下一代AI规范?

OpenSpec标准兼容性分析&#xff1a;Qwen3-VL-30B是否符合下一代AI规范&#xff1f; 在人工智能迈向多模态融合的今天&#xff0c;一个核心问题正摆在开发者和架构师面前&#xff1a;我们究竟需要的是参数不断膨胀的“巨无霸”模型&#xff0c;还是能够在真实场景中高效运行、智…

作者头像 李华
网站建设 2026/5/26 6:54:23

Windows虚拟显示器完全指南:5分钟打造免费多屏办公环境

Windows虚拟显示器完全指南&#xff1a;5分钟打造免费多屏办公环境 【免费下载链接】virtual-display-rs A Windows virtual display driver to add multiple virtual monitors to your PC! For Win10. Works with VR, obs, streaming software, etc 项目地址: https://gitco…

作者头像 李华
网站建设 2026/5/26 6:53:42

diskinfo查看磁盘健康状态确保Qwen3-VL-30B稳定运行

diskinfo查看磁盘健康状态确保Qwen3-VL-30B稳定运行 在部署像 Qwen3-VL-30B 这类超大规模多模态模型的今天&#xff0c;系统稳定性早已不再仅仅依赖于GPU算力或网络带宽。真正决定服务可用性的&#xff0c;往往是那些“不起眼”的基础设施环节——比如一块默默工作的NVMe固态硬…

作者头像 李华
网站建设 2026/5/26 3:08:07

Dify流程编排调用ACE-Step API:实现多步音乐创作自动化

Dify流程编排调用ACE-Step API&#xff1a;实现多步音乐创作自动化 在短视频、独立游戏和数字广告内容爆炸式增长的今天&#xff0c;背景音乐&#xff08;BGM&#xff09;的需求量正以前所未有的速度攀升。然而&#xff0c;专业作曲成本高、周期长&#xff0c;而版权音乐库又常…

作者头像 李华