当前位置:   article > 正文

Python项目实现之分解质因数_import numpy as np n = int(input()) m = int(input(

import numpy as np n = int(input()) m = int(input()) # 实现分解质因数,并返回

你好,欢迎查看我的第四个笔记。本人是某不知名大学数学系大一新生,由于对计算机感兴趣,所以跟着B站上老师学习python语言。每道题目我都尽我所能地讲清楚,如果有什么看不懂的地方欢迎在评论区留言,大家一起学习共同进步。

项目9:分解质因数

         例如:   |    输入:45            |

                       |    输出 45=3*3*5    |

解析:

1.     先创建一个判断输入的数是否为质数的函数

        若传入的参数n为质数,返回flag=Ture;反之返回False

        详情见第一弹项目1:

  1. def zhishu(n):#创建一个判断质数的函数,若n为质数,flag=Ture;反之False
  2. flag=True
  3. for i in range(2,n):
  4. if n%i==0:
  5. flag=False
  6. break
  7. return flag
2.     把所有的质因数放在一个列表(zhi)中
  1. num=int(input("num="))
  2. n=num#下面的操作都是对n做的,起到一个保护num变量的作用
  3. zhi=[]#创建一个空列表,用来存放质因数
  4. while not zhishu(n):#当n不是质数时
  5. for i in range(2,n):
  6. if n%i==0:#如果i是质因数
  7. zhi.append(i)#就把i放到zhi中
  8. n//=i#更新n,相当于 n=n//i
  9. break#条件成立的话就跳转到while,进行判断,再循环
  10. if zhishu(n):#最终的n一定会变成质数,这时n不再进入while循环,因此我们需要把这个质数放在zhi里面
  11. zhi.append(n)

为什么在第9行用n //=n,而不用n /=n呢?

        如果写成n /=n 将报错如下。翻译过来就是 float 类型不能被翻译为int 类型,言下之意,我们这里需要的是 int 类型,因此使用整除符号(//)。

3。   最后格式化输出

        用for循环遍历zhi中的所有元素(即num的所有质因数),再按照 zhi[x]* 的格式输出

        值得关注的是最后一项输出后没有尾巴的那个*,所以我们单独判断了一下。

  1. #下面就是输出语句了
  2. print(f"{num}=",end='')
  3. for x in range(len(zhi)):
  4. if x !=len(zhi)-1:
  5. print(f"{zhi[x]}*",end='')
  6. else:
  7. print(f"{zhi[x]}")

代码运行结果:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/669376
推荐阅读
相关标签
  

闽ICP备14008679号