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循环遍历整个列表,取出其中的数字