qq_57129135 2022-04-26 11:23 采纳率: 100%
浏览 42
已结题

Python栈的应用

设计一个算法,利用栈实现质因数分解,要求输出格式形如:300=55322

  • 写回答

1条回答 默认 最新

  • 不会长胖的斜杠 后端领域新星创作者 2022-04-26 11:55
    关注

    望采纳,谢谢

    
    import math
    class Stack:
         def __init__(self):
             self.items = []
    
         def isEmpty(self):
             return self.items == []
    
         def push(self, item):
             self.items.append(item)
    
         def pop(self):
             return self.items.pop()
    
         def peek(self):
             return self.items[len(self.items)-1]
    
         def size(self):
             return len(self.items)
    
    def is_prime(x):
        if x == 2:
            return True
        for i in range(2, int(math.sqrt(x)) + 1):
            if x % i == 0:
                return False
        return True
    
    s1 = Stack()
    num = int(input())
    while not is_prime(num):
        for i in range(2, int(math.sqrt(num)) + 1):
            if (num % i == 0 and is_prime(i)):
                s1.push(i)
                num //= i
                break
    s1.push(num)
        
    while not s1.isEmpty():
        print(s1.pop(),end='')
    
    
    

    img

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 5月3日
  • 已采纳回答 4月26日
  • 创建了问题 4月26日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部