当前位置: 首页 > news >正文

快乐数——哈希表

编写一个算法来判断一个数n是不是快乐数。

「快乐数」定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是无限循环但始终变不到 1。
  • 如果这个过程结果为1,那么这个数就是快乐数。

如果n快乐数就返回true;不是,则返回false

思路:不容易判断的点在于无限循环的情况。

数字平方和一定会让数变小

设一个数有 k 位,那么它的最大值是:10^k - 1。

它的各位数字最大是 9。每位平方最大是 81。

所以 k 位数的平方和最大是:81 * k。

而 k 位数本身至少是:10^(k-1)

比较:

位数最小 k 位数数位平方和最大值
310081 * 3 = 243
4100081 * 4 = 324
51000081 * 5 = 405

你会发现:

从 4 位数开始,下一步一定会掉到 324 以下。

从这开始,无论你多大,最终都会掉进一个固定的小范围内。

✔ 情况 A:最终变成 1(快乐)

✔ 情况 B:在某处形成循环(不快乐)

所以无限循环,也就是非快乐数,必然意味着某个数重复出现。

class Solution: def isHappy(self, n: int) -> bool: s=set() while True: n=self.getSum(n) if n==1: return True else: if n in s: return False s.add(n) def getSum(self,n): sum = 0 while n: sum+=(n%10)**2 n//=10 return sum print(Solution().isHappy(19))
http://www.cnnetsun.cn/news/14891.html

相关文章:

  • DBeaver数据库对象搜索失效的5分钟紧急修复指南
  • PHP 15 个高效开发的小技巧
  • 三级防护+119种语言:Qwen3Guard-Gen重新定义2025大模型安全标准
  • Brotli解压引擎深度解密:从位流到字节的魔法转换
  • 深度解析 MySQL 与 MCP 集成:从环境构建到 AI 驱动的数据交互全流程
  • 5个理由选择Google Assistant SDK Python版打造智能语音设备
  • 卷心菜矮砧密植:水肥一体化系统的详细铺设要点
  • Automa模板市场:让每个用户都能安全享受社区智慧
  • Citra模拟器完整教程:3步在电脑畅玩3DS游戏
  • Step-Audio 2 mini:2025开源语音模型如何重塑企业交互新范式
  • 13、BPF 流量控制分类器详解
  • 14、快速数据路径(XDP):原理、模式与应用指南
  • 3步搞定Snap.svg动画导出:从SVG到视频GIF的完整指南
  • Java ArrayList扩容机制深度解析
  • 手把手教你Windows系统安装pgvector:PostgreSQL向量搜索实战指南
  • xtb量子化学计算终极实战指南:从新手到专家的完整路径
  • Windows权限维持技术攻击手法与深度防御浅析
  • Windows系统映像劫持:网络安全中的“李代桃僵”战术
  • 几内亚硬建钢铁厂?中方点破 5 大短板!最致命问题中国一眼看穿!
  • Navicat重置工具完整指南:轻松解决试用期限制
  • 19、Linux 新软件安装全攻略
  • 使用STM32单片机进行串口通信的过程描述
  • JetBrains Maple Mono字体深度体验与配置指南
  • 【Java毕设源码分享】基于springboot+vue的个人博客系统的设计与实现(程序+文档+代码讲解+一条龙定制)
  • PaddleSpeech模型版本管理终极指南:从混乱到秩序
  • 闪电AI文档转换Lite:离线免费的全能文档处理神器
  • Windows系统pgvector一键部署攻略:告别编译烦恼,轻松开启向量搜索
  • 伊朗地毯数据集,波斯地毯Lechak-Toranj和Afshan图案分类,计算机视觉机器学习训练,纺织设计分析增强样本,装饰艺术特征提取对称检测算法,纹理分析Gabor滤波,个性化定制图案生成
  • [基础算法学习]backtrack回溯法(三):从N皇后、解数独带你掌握棋盘回溯问题
  • 终极指南:如何从零开始掌握Lean数学库mathlib?完整教程助你快速入门