python 算法题——快乐数的多种解法
题目描述:
编写一个算法来确定一个数字是否“快乐”。 快乐的数字按照如下方式确定:从一个正整数开始,用其每位数的平方之和取代该数,并重复这个过程,直到最后数字要么收敛等于1且一直等于1,要么将无休止地循环下去且最终不会收敛等于1。能够最终收敛等于1的数就是快乐的数字。
例如:19是一个快乐数字,计算过程如下:
1^2+9^2=82 8^2+2^2=68 6^2+8^2=100 1^2+0^2+0^2=1 要求:当输入快乐的数字时,输出True,否则输出False。
思路:
1. 当输入的不是快乐数字时,会陷入一个无限循环,因此增加一个计数器 count 用来统计计算次数。设定当 count 达到2000次时,认为该数字不是快乐数字,跳出循环结束计算。 2. 因为不确定输入的数字会是几位数,因此不采用除法和取模的方法来获得数字的每一位数,而是利用 for 循环获取字符串类型数字的每一位来计算平方和。
代码:
#快乐的数字
def getSumofSquares(num):
numStr=str(num) #将待计算的数字转换成字符串类型
sum=0
digitls=[int(x) for x in numStr] #从字符串中提取出每一位数字存入一个列表
#注:该步略显多余,因为python中字符串可以和列表一样切片取值或循环,见下方更新部分
#print(digitls)
for i in digitls:
sum += i**2
return sum
def main():
n = input() #输入一个正整数
sumofSqrs = eval(n)
count = 0
while sumofSqrs != 1:
sumofSqrs = getSumofSquares(sumofSqrs)
count += 1
if count > 2000: #当计算次数超过2000次时,跳出循环结束计算
print("False")
break
else:
print("True")
main()
改良版
根据网友在评论区提出的不快乐的数字最终会在 [4,16,37,58,89,145,42,20] 这些数字中无限循环,因此可以加入判断,当数字变为这些数字里的任意一个(比如4)时就结束循环,输出False,从而避免无限循环的产生。
修改后的代码:
#(新)快乐的数字
def getSumofSquares(num):
numStr=str(num)
sum=0
for i in numStr:
sum += int(i)**2
return sum
def main():
n = input() #n为一个正整数
sumofSqrs = eval(n)
while sumofSqrs != 1 and sumofSqrs != 4: #或 while sumofSqrs not in [1,4,16,37,58,89,145,42,20]
sumofSqrs = getSumofSquares(sumofSqrs)
else:
if sumofSqrs == 1:
print("True")
else:
print("False")
main()
采用递归
def happy(n):
try:
if n==1:
print('True')
else:
new = str(n)
sum = 0
for c in new:
sum += int(c)**2
return happy(sum)
except Exception as e:
print('False')
# print(e)
n = eval(input())
happy(n)
数学方法
d = {}
while True:
m = 0
while n > 0:
m += (n%10)**2
n //= 10
if m in d:
return False
if m == 1:
return True
d[m] = m
n = m
优化过的
class Solution(object):
def isHappy(self, n):
"""
:type n: int
:rtype: bool
"""
record = []
sq_sum = 0
se_n = n
while se_n != 1:
sq_sum = 0
while se_n > 0:
sq_sum += (se_n % 10) * (se_n % 10)
se_n = se_n / 10
if sq_sum in record:
return False
record.append(sq_sum)
se_n = sq_sum
return True
(资源库 www.zyku.net)
原文链接:https://blog.csdn.net/u013378642/article/details/80861104
您可能感兴趣的文章
- 01-12AR仙-AR仙应用软件功能介绍
- 09-14华为手机隐藏录音通知步骤分享
- 01-11九星漫画-九星漫画应用软件功能介绍
- 12-28中网院-中网院应用软件功能介绍
- 06-16PHP怎么设置文件777权限
- 02-22DedeCMS会员投稿自动加积分改为投稿审
- 09-27华为nova9启用分屏步骤介绍
- 01-17名校邦-名校邦应用软件功能介绍
- 01-12汽车交易宝-汽车交易宝应用软件功能介
- 04-06一加9录制系统声音开启教程
- 03-13wordpress自定义上传文件类型的方法
- 03-22realmev15设置锁屏时抬起亮屏方法
- 07-08html中iframe如何设置高度和宽度
- 09-28Git add 命令添加所有改动的内容
- 04-24python备份文件的脚本
- 01-29红米note9pro开启热点方法
- 01-08vivox60pro+设置语音唤醒方法介绍
- 01-19气泡盒-气泡盒应用软件功能介绍
- 12-17红米note8省电模式在哪打开
- 04-18小米11pro开启全面屏手势设置方法
最近更新
阅读排行
猜你喜欢
- 07-07MySQL中的数据类型binary和varbinary
- 02-28oppo手机浏览器取消禁止访问方法
- 07-05Linux nc命令
- 03-30SVN创建分支与合并
- 11-15抖音@我记录怎样查看
- 12-13HTML <time> 标签
- 02-20华为freebuds3绑定手机方法
- 12-23华为mate30pro有没有杜比音效
- 03-07华为watch3pro开启睡眠监测方法
- 04-08小米11ai通话功能设置方法