原题链接:蓝桥杯基础练习VIP-分解质因数
解题思路:
思路是[a,b]、我用一个循环[a,b],然后再用一个函数将每一个数的质因数存入到列表、然后再打印到控制台再清空列表继续记录下一个数的质因数。
因数的拆分用了一个递归、就是先找到一个数的第一个质因数、然后将质因数对应的因数再放在函数进行,结束条件是另一个因数也是质数结束。详情见代码
参考代码:
def print_result(n,nums):
flag = 1 #标记当前数的第一个质因数
for i in range(2,n//2+1):
'''如果是质因数就加入到存质因数的列表里'''
if n%i == 0 and isPrime(i):
nums.append(i)
flag = i
break
if flag != 1:
#不是1说明有质因数、则将另一个因数拆分成质因数
print_result(n//flag,nums)
else:
#是1说明自己是质数
nums.append(n)
'''素数的判断'''
def isPrime(n):
for i in range(2,n//2):
if n%i == 0:
return False
return True
def main():
a,b = map(int,input().split())
nums = [] #用来存质因素
for i in range(a,b+1):
'''[a,b]循环打印'''
print(str(i),end="=")
print_result(i,nums)
'''按要求打印'''
for j in range(len(nums)):
if j == 0:
print(nums[j],end="")
else:
print("*"+str(nums[j]),end="")
print()
#清空列表、记录下一个数的质因数
nums.clear()
main()0.0分
3 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复