python2.7练习小例子(十二)
12):题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
程序源代码:
#!/usr/bin/python
# -*- coding: UTF-8 -*- for n in range(100,1000):
i = n / 100
j = n / 10 % 10
k = n % 10
if n == i ** 3 + j ** 3 + k ** 3:
print n
以上实例输出结果为:
153
370
371
407
将三位数看成由三个数组成,并判断其各位数字立方和是否等于该数本身:
#!/usr/bin/python
# -*- coding: UTF-8 -*- for x in range(1,10):
for y in range(0,10):
for z in range(0,10):
s1=x*100+y*10+z
s2=pow(x,3)+pow(y,3)+pow(z,3)
if s1==s2:
print "水仙花数有:%7ld" %(s1)
#!/usr/bin/python
# -*- coding: UTF-8 -*- for i in range(100, 1000):
s = str(i)
if int(s[0]) ** 3 + int(s[1]) ** 3 + int(s[2]) ** 3 == i:
print(i)
#!/usr/bin/env python
# -*- coding: UTF-8 -*- L = []
for n in range(100,1000):
i = n / 100
j = n /10 % 10
k = n % 10
if n == i ** 3 + j ** 3 + k ** 3:
if n == pow(i,3) + pow(j,3) +pow(k,3):
L.append(n)
print(L)
print len(L)
兼容 Python2.x 与 Python3.x,Python3.x 取整为 //,而不是 /, 参考方法:
#!/usr/bin/python3
# -*- coding: UTF-8 -*- for i in range(100,1000):
h=i//100
t=(i-100*h)//10
s=i-100*h-10*t
if i==h**3+t**3+s**3:
print(i)
#!/usr/bin/env python
# -*- coding: UTF-8 -*- a = 1
b = 1
c = 1
for a in range(0,10):
for b in range(0,10):
for c in range(0,10):
if int(a)**3+int(b)**3+int(c)**3 == a*100+b*10+c and a != 0:
x = a*100+b*10+c
print(x)
#!/usr/bin/python
# -*- coding: UTF-8 -*- for x in range(10):
for y in range(10):
for z in range(10):
w = x*100 + y*10 + z
if (w>100) and (w == x**3 + y**3 + z**3):
print w
#!/usr/bin/python
# -*- coding: UTF-8 -*- #列表解析法
l=[x**3+y**3+z**3 for x in range(0,10) for y in range(0,10) for z in range(0,10) if (str(x)+str(y)+str(z))==str(x**3+y**3+z**3)]
print(l)
#!/usr/bin/python
# -*- coding: UTF-8 -*- for n in range(100,1000):
m = n
sumValue = 0
while(m>0):
(m,r) = divmod(m, 10)
sumValue += r ** 3
if n == sumValue:
print(n)
#coding:UTF-8 print [i for i in range(100,1000) if (i/100)**3+((i-i/100*100)/10)**3+(i%10)**3 == i]
Python3 参考:
#水仙花数是指一个 n 位数(n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身 #生成器函数ppdi,可生成十进制自然数中的所有水仙花数,共有88个
def ppdi():
n=3
while 1:
#生成器推导式
l=(i for i in range(10**(n-1),10**n) if sum([int(str(i)[j])**n for j in range(n)])==i)
yield l
n+=1 #最大的水仙花数有39位
def f(max):
for i in ppdi():
for j in i:
if j<10**max:
print(j)
else:
break
if j>10**max:
break #为环保起见,建议7位以内即可
f(5)
这次的小例子有点意思。开始我都不知道水仙花数是什么鬼?嘿嘿。。。
如果感觉不错的话,请多多点赞支持哦。。。
原文链接:https://blog.csdn.net/luyaran/article/details/80049547
python2.7练习小例子(十二)的更多相关文章
- python2.7练习小例子(二十九)
29):1.题目:按相反的顺序输出列表的值. #!/usr/bin/python # -*- coding: UTF-8 -*- a = ['one', 'two', 'three'] for ...
- python2.7练习小例子(二十八)
28):题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母. 程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. ...
- python2.7练习小例子(二十四)
24):1.题目:利用递归方法求5!. 程序分析:递归公式:fn=fn_1*4! #!/usr/bin/python # -*- coding: UTF-8 -*- def fact( ...
- python2.7练习小例子(二十七)
27):题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同. #!/usr/bin/python # -*- coding: UTF-8 -* ...
- python2.7练习小例子(二十三)
23):题目:求1+2!+3!+...+20!的和. 程序分析:此程序只是把累加变成了累乘. #!/usr/bin/python # -*- coding: UTF-8 -*- n = ...
- python2.7练习小例子(二十二)
22):题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和. 程序分析:请抓住分子与分母的变化规律. #!/usr/bin/pyt ...
- python2.7练习小例子(二十六)
26):题目:给一个不多于5位的正整数,要求:一.求它是几位数,二.逆序打印出各位数字. 程序分析:学会分解出每一位数. 程序源代码: #!/usr/bin/python # ...
- python2.7练习小例子(二十)
20):题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上 ...
- python2.7练习小例子(二十五)
25):题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁.问第4个人岁数,他说比第3个人大2岁.问第三个人,又说比第2人大两岁.问第2个人,说比第一个人大两岁.最后问第一个人,他 ...
- python2.7练习小例子(二)
2):题目:企业发放的奖金根据利润提成.利润(I)低于或等于10万元时,奖金可提10%:利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%:2 ...
随机推荐
- Cloud Foundry Session Affinity(Sticky Session)的实现
会话保持(Session Affinity),有时又称粘滞会话(Sticky Sessions), 是负载均衡领域设计需要着力解决的重要问题之一,也是一个相对比较复杂的问题. 会话保持是指在负载均衡器 ...
- 为什么使用中间件下载时总是收到警告消息Object is in status Wait
在使用中间件从ERP下载对象时,正常情况下应该看到如下提示消息: 然而有时遇到的是黄色的警告消息:Object is in status Wait. 如何自己排错呢?在函数SMOF0_INIT_DNL ...
- MHA 一主一从搭建
安装基本环境介绍 一主一从 MHA manager & slave node2 192.168.56.27 Master机器 node1 192.168.56.26 VIP 19 ...
- 《编程导论(Java)·9.3.1回调·3》回调的实现
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/yqj2065/article/details/31441221 接<9.3.1Java回调 · ...
- HDU 1521 指数型母函数
方法一: DFS 方法二:生成函数 每个数可以重复一定次数,求排列组合数,这是裸的指数型生成函数: #include <bits/stdc++.h> using namespace std ...
- react开发环境准备
使用reactjs,我们有两种方式 一种是通过script标签引入reactjs,这是一种比较古老的编码方式了, 如果我们的项目比较大,你会对项目js进行拆分,然后页面就会通过script标签加载很多 ...
- 访问XML文件中的信息
- C#结构体和字节数组的转换函数
在通信过程中,一般我们都会操作到字节数组.特别是希望在不同语言编程进行操作的时候. 虽然C#提供了序列化的支持,不用字节数组也行.但操作字节数组肯定会碰到. 一般都会采用结构来表示字节数组.但结构 ...
- center os 文件读写权限
五.使用chmod和数字改变文件或目录的访问权限文件和目录的权限表示,是用rwx这三个字符来代表所有者.用户组和其他用户的权限.有时候,字符似乎过于麻烦,因此还有另外一种方法是以数字来表示权限,而且仅 ...
- JavaScript 表单处理
表单对象的属性 name action method encoding target elements 表单对象的方法 submit reset 表单元素事件 文本域事件:onFocus(获得焦点) ...