任意4位数组合输出
如果给定任意的4位数,比如,3,5,6,9 ,要得到每一位都不重复的4位数的所有组合;比如,3569,3659等;3566,5399,3565等不算,输出具体的组合如何实现呢?
求各位大大 的实现代码,得到结果后如何验证呢?{:5_94:} num1 = input("请输入第一位数:")
num1 = int(num1)
num2 = input("请输入第二位数:")
num2 = int(num2)
num3 = input("请输入第三位数:")
num3 = int(num3)
num4 = input("请输入第四位数:")
num4 = int(num4)
nums =
for i in range(4):
for j in range(4):
if i == j:
continue
for k in range(4):
if i == k or j == k:
continue
for m in range(4):
if i == m or j == m or k == m:
continue
print(nums, nums, nums, nums, sep='', end=' ')
验证的话总共4×3×2×1=24种组合,大概看一下就知道了 这个可用 itertools 模块的 permutations 函数实现
你这个意思就是全排列 来点反向思维:既然全部的四位数总数量并不多,何不枚举所有可能的答案然后检查是否满足要求?
reference=set(digit for digit in input())
print(list(filter(lambda check: set(digit for digit in str(check)) == reference, range(1000, 10000))))
这里假设输入时直接输入给定的四个数字,不会包含任何多余字符,同时输入的四个数字一定是互不相同的。 小甲鱼老湿的方法 假设题目不变,要得到不重复的3位数的所有组合,应该如何调整代码呢? num1 = input("请输入第一位数:")
num1 = int(num1)
num2 = input("请输入第二位数:")
num2 = int(num2)
num3 = input("请输入第三位数:")
num3 = int(num3)
nums =
for i in range(3):
for j in range(3):
if i == j:
continue
for k in range(3):
if i == k or j == k:
continue
print(nums, nums, nums, sep='', end=' ')
依葫芦画瓢调整如上面代码
页:
[1]