其实这个题的思路还是很简单,但是遍历起来很麻烦,但是现在至今没有找到一个好的方法。
我看网上的答题区有使用9的阶层来解题的,那样操作起来会更复杂麻烦。
我的想法是,第一个数作为一个基数,因为三个数的范围都在1000以内,因此最小的数一定是大于123小于329的:
s=[]#首先先定义一个数组来存放每次每个数字的各个位上的数字,来判断是否有重复值
newl=[]#存放筛选好的数据
for num in range(123,329):
a=num
b=a*2
c=a*3
s.clear()#将s清空
s=[a//100,a//10%10,a%10,#依次表示a的百位,十位和个位
b//100,b//10%10,b%10,
c//100,c//10%10,c%10,]
flag=1#做一个标记来判断每次列表s中的元素是否符合要求
for i in range(8):#仅访问i和i后面的数字所以最后一个元素步访问
if flag==0 or s[i]==0:#这里注意判断flag的值是否正确
break
for j in range(i+1,9):
if s[j]==0 or s[i]==s[j]:
flag=0
break#一旦有元素不符合立即跳出,节约时间
if flag:
newl.append(a)
newl.append(b)
newl.append(c)#将符合的a,b,c按序装入新的列表
print(newl)