Python4个数字组成无重复的三位数

#题目 有四个数字:1、2、 3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?

#1.暴力法 根据题意写

arr=[] #用于存放三位数

count=0 #用于计数

for i in range(1,5):

 for j in range(1,5):

  for k in range(1,5):

   num=i*100+j*10+k

   if i!=j and i!=k and j!=k and num not in arr: #如果三个数字不相同 并且无重复

    arr.append(num)

    count+=1

print(arr)

print(count)

2.引用itertools模块i

mport itertools

lst=list(itertools.permutations([1,2,3,4],3)) #表示 用1,2,3,4 四个数 选3个

print(lst)

此时,这里的lst # A_4^3 = (4)!/(4-3)! = (4*3*2*1)/1 = 24 共有24种情况

这是在控制台输出的[(1, 2, 3), (1, 2, 4), (1, 3, 2), (1, 3, 4), (1, 4, 2), (1, 4, 3), (2, 1, 3), (2, 1, 4), (2, 3, 1), (2, 3, 4), (2, 4, 1), (2, 4, 3), (3, 1, 2), (3, 1, 4), (3, 2, 1), (3, 2, 4), (3, 4, 1), (3, 4, 2), (4, 1, 2), (4, 1, 3), (4, 2, 1), (4, 2, 3), (4, 3, 1), (4, 3, 2)]

接着 再转换为3位数就行了

arr=[100*t[0]+10*t[1]+t[2] for t in lst] #列表生成式

print(arr,len(arr))

这里用到了一个列表生成式34ce374585ad4a49baae00f0155a9c51.jpg

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值