练习题目内容和要求如下:
(一) 概述:对10个10~100随机整数进行因数分解。
(二) 编程要求:
- 产生一个随机数列表,a[n](包含10个10~100之间的随机数,其中,每个随机数均为“整数”且“不重复”)
- 对a[n]中每个元素进行因数分解,将分解结果输出到b[n]中,其中b[i]为a[i]的分解结果的列表(例如:a[2]45,则b[2][3,3,5])
- 显示a[n],b[n]两个列表(要求,a[i]与b[i]显示在同1行,a[i]与b[i]之间用“=”分隔,b[i]内部各元素之间用“”分隔。例如:“45=33*5”)
代码:
import random
def random_num(n,s):#生成10个不同的10~100的随机正整数
data=random.sample(range(10,s),n)
return data
def factors(num):
i=2
t=[]
while(i<num):
if num%i==0:
num=num/i#若num能本i整除,则更新num,寻找其他因数,i重新从2开始增加
t.append(i)
i=2
else:
i=i+1
t.append(round(num))
if len(t)==1:#若num为素数,则它的因数是它本身及1
t.append(1)
return t
def main():
n,s=eval(input("请输入随机整数数量与上限(用逗号隔开):"))#控制变量n,s分别代表随机整数的数量、最大范围
a=random_num(n,s)
b=[]#用来存储a中元素的因数分解结果,为嵌套列表
for k in a:
temp=factors(k)
b.append(temp)
temp=[]
for num,fac in zip(a,b):
print(str(num)+'='+'*'.join(map(str,fac)))
main()