首页 > 其他 > 详细

输出所有素数因子

时间:2021-08-19 08:23:00      阅读:11      评论:0      收藏:0      [点我收藏+]
 1 #include<iostream>
 2 #include<cmath>
 3 using namespace std;
 4 
 5 // print all prime factor
 6 void print(int n)
 7 {
 8     // 将n除成奇数
 9     while(n%2==0)
10     {
11         cout<<2<<" ";
12         n=n/2;
13     }
14 
15     //唯一的偶素数2,因为n是个奇数,所以i+=2
16     for(int i=3;i<sqrt(n);i+=2)
17     {
18         while(n%i==0)
19         {
20             cout<<i<<" ";
21             n=n/i;
22         }
23     }
24 
25 //    if(n==1)
26 //        return;
27 //    else
28 //        cout<<n<<" ";
29 
30     //最后,如果n>2则是一个素数,或者是n=1
31     if(n>2)
32         cout<<n<<endl;
33 
34 }
35 
36 
37 int main()
38 {
39     int n;
40     cin>>n;
41     print(n);
42     return 0;
43 }

 

参考链接:https://www.geeksforgeeks.org/print-all-prime-factors-of-a-given-number/

 

输出所有素数因子

原文:https://www.cnblogs.com/cwfeng/p/15158512.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!