妙先生


私信TA

用户名:uq_57083779177

访问量:24899

签 名:

妙啊!

等  级
排  名 235
经  验 6011
参赛次数 0
文章发表 73
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:
    思路是[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 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区

好强
2024-03-12 15:53:39
思路好清晰!膜拜大神
2022-03-01 22:30:39
  • «
  • 1
  • »