发布时间:2019-08-29 07:40:28编辑:auto阅读(5632)
1 # 题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
2 num = [1,2,3,4] 3 n = [] 4 for x in num: 5 for y in num: 6 for z in num: 7 if x != y and x != z and y != z: 8 m = x*100 + y*10 + z 9 n.append(m) 10 11 print('可以组成无重复的三位数有%d个'%(len(n))) 12 print('它们分别是:') 13 print(n)
运行结果:
[root@HK code_100]# python code_1.py 可以组成无重复的三位数有24个 它们分别是: [123, 124, 132, 134, 142, 143, 213, 214, 231, 234, 241, 243, 312, 314, 321, 324, 341, 342, 412, 413, 421, 423, 431, 432]
脚本解释:
2 num = [1,2,3,4] # 将这四个数字定义成一个列表,以便for遍历这一些数字,也可以使用rang(1,5)来表示 3 n = [] #定义一个空list,用来存放符合要求的数字,之所以用list是为了可以用len()函数取长度 4 for x in num: #用三个for循环来遍历所有可能的组合 5 for y in num: 6 for z in num: 7 if x != y and x != z and y != z: # 排除有重复数字的三位数 (不知道有没有简单的表达式可以表示这个条件,没多想) 8 m = x*100 + y*10 + z #取得符合要求的数字 9 n.append(m) #将符合要求的数字用append方法添加到列表n中 10 11 print('可以组成无重复的三位数有%d个'%(len(n))) # 格式化输出列表长度,也就是列表个数 12 print('它们分别是:') 13 print(n) # 列出符合要求的数字,也可以用for循环遍历整个列表,取出其中的数字
上一篇: Python学习入门基础教程(lear
下一篇: Python的迭代器协议
47879
46443
37332
34772
29344
26007
24960
19976
19578
18074
5821°
6447°
5961°
5987°
7093°
5937°
5977°
6471°
6434°
7817°