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练习小例子(十二)的更多相关文章

  1. python2.7练习小例子(二十九)

        29):1.题目:按相反的顺序输出列表的值. #!/usr/bin/python # -*- coding: UTF-8 -*- a = ['one', 'two', 'three'] for ...

  2. python2.7练习小例子(二十八)

    28):题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母.     程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. ...

  3. python2.7练习小例子(二十四)

        24):1.题目:利用递归方法求5!.     程序分析:递归公式:fn=fn_1*4! #!/usr/bin/python # -*- coding: UTF-8 -*- def fact( ...

  4. python2.7练习小例子(二十七)

        27):题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同.      #!/usr/bin/python # -*- coding: UTF-8 -* ...

  5. python2.7练习小例子(二十三)

        23):题目:求1+2!+3!+...+20!的和.     程序分析:此程序只是把累加变成了累乘. #!/usr/bin/python # -*- coding: UTF-8 -*- n = ...

  6. python2.7练习小例子(二十二)

        22):题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和.     程序分析:请抓住分子与分母的变化规律. #!/usr/bin/pyt ...

  7. python2.7练习小例子(二十六)

        26):题目:给一个不多于5位的正整数,要求:一.求它是几位数,二.逆序打印出各位数字.     程序分析:学会分解出每一位数.     程序源代码: #!/usr/bin/python # ...

  8. python2.7练习小例子(二十)

        20):题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上 ...

  9. python2.7练习小例子(二十五)

        25):题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁.问第4个人岁数,他说比第3个人大2岁.问第三个人,又说比第2人大两岁.问第2个人,说比第一个人大两岁.最后问第一个人,他 ...

  10. python2.7练习小例子(二)

        2):题目:企业发放的奖金根据利润提成.利润(I)低于或等于10万元时,奖金可提10%:利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%:2 ...

随机推荐

  1. 增强for循环 java.util.ConcurrentModificationException

    Java中的Iterator功能比较简单,并且只能单向移动: (1) 使用方法iterator()要求容器返回一个Iterator.第一次调用Iterator的next()方法时,它返回序列的第一个元 ...

  2. Oracle transport tablespace

    本来没想过发布这个文章,只是周边有一朋友工作中遇到合并数据库的情况,他是通过expdp提取出五个库对象,然后impdp到新库里面.我觉得这种方法特别耗时,尤其在数据量比较大的时候.这种时候我觉得采用表 ...

  3. Jquery的部分插件

    jQuery Easing:jQuery 动画效果扩展 jQuery Migrate:jQuery 应用迁移辅助插件Modernizr:专为HTML5和CSS3开发的功能检测类库jQuery Flex ...

  4. May 18th 2017 Week 20th Thursday

    The greater the struggle, the more glorious the triumph. 挑战愈艰巨,胜利愈辉煌. Sometimes it would be better t ...

  5. mvc做网站怎么在mvc中直接访问.html网页 [问题点数:20分]

    最近用.net mvc做一个网站 我想在mvc中直接访问一个 .html页面 怎么设置一下啊 现在直接访问是404不让访问的 放到view文件夹外面...

  6. Android(java)学习笔记16:多线程 - 定时器概述和使用

    1. 定时器: 定时器是一个应用十分广泛的线程工具,可用于调度多个定时任务以后台线程的方式执行. 在Java中,可以通过Timer和TimerTask类来实现定义调度的功能 Timer public ...

  7. ZOJ 2386 容斥原理

    题意:给出n个数,和m(1<=m<=200 000 000),求1~M中能被这n个数其中任意一个数整除的个数: 分析:n范围很小,可以枚举选择被哪些数整除,被奇数个整数整除加m/这个n个数 ...

  8. CSU 1023 修路(二分+模拟)

    前段时间,某省发生干旱,B山区的居民缺乏生活用水,现在需要从A城市修一条通往B山区的路.假设有A城市通往B山区的路由m条连续的路段组成,现在将这m条路段承包给n个工程队(n ≤ m ≤ 300).为了 ...

  9. HDU 1111 Secret Code(数论的dfs)

    Secret Code Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit ...

  10. sql得到表中的列信息

    取列全部用的 sys. 中的表 CTE:WITH name AS() 用法:   sql树形查询 ①主键信息 SELECT ic.column_id, ic.index_column_id, ic.o ...