当前位置:首页 > 题解目录 > 正文内容

因子分解

亿万年的星光5年前 (2021-01-28)题解目录2125

【题目描述】
输入一个数,输出其素因子分解表达式。

【输入描述】
输入一个整数 n (2≤n<100)。

【输出描述】

输出该整数的因子分解表达式。表达式中各个素数从小到大排列。
如果该整数可以分解出因子a的b次方,当b大于1时,写做 a^b ;当b等于1时,则直接写成a。

【样例输入1】
60

【样例输出1】
2^2*3*5

【样例输入2】


1323


【样例输出2】

3^3*7^2


【分析】

(1)解题思想可以用递归,寻找子问题。也可以用暴力穷举思想
(3)所有的数字都是这个数的质因子的次方,这个题应该改成质因子分解。
(4)要求所有素因子从小到大排列
(5)如果一次性就除完,就没有中间的符号了(比如9),因此需要加个flag来判断是不是第一次

能被4整除的一定能被2整除,同理,6,8,10等一样

同理,能被6整除, 一定能被3整除。

可以想一下桶排的策略,用来计算次数

 while(x%y==0)
 {
        x/=y;
        a[y]++;
 }
//x是数值,y是第一个质数,从2开始枚举,这种方法是不会遇到4这种数字

【参考代码1】

#include<iostream>
#include<cstdio>
#include<cstring>
#define N 10001
using namespace std;
int n;
int a[N],b[N];
void calculate(int x,int y)
{
  //x是数本身,y是质数
   if(x==0||y>x)
       return;
   while(x%y==0)
   {
       x/=y;
       a[y]++;
   }
   calculate(x,y+1); //下一个数
}
int main()
{
   bool flag=false; //用来判断是不是第一次输出
   cin>>n;
   calculate(n,2); //n值和第一个质数
   for(int i=2;i<=n;i++)
   {
       if(flag&&a[i])
           cout<<"*";
       if(a[i])
           flag=true;
       if(a[i]==1)
           cout<<i;
       else if(a[i]>1)
           cout<<i<<"^"<<a[i];
   }
   cout<<endl;
   return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:
返回列表

上一篇:分数求和

下一篇:单词提取

相关文章

【题解】密码截获

【题目描述】Catcher是MCA国的情报员,他工作时发现敌国会用一些对称的密码 进行通信,比如像这些ABBA,ABA,A,123321,但是他们有时会在开始或结束时加入一些无关的字符以防止别国破解。...

【题解】最小新整数

4.最小新整数(smallest.cpp)【题目描述】假如:有一个十进制正整数n,每个数位上数字均不为0,并且0<n<1000000000。n的位数为m。先在从m位中删除k位(0<k...

素数个数

【题目描述】编程求2~n(n为大于2的正整数)中有多少个素数。【输入描述】输入n (2<= n <=50000)【输出描述】素数个数【输入样例】10【输出样例】4#include<i...

【题解】运动员和训练师的最大匹配数

【题目描述】给你一个下标从 0 开始的整数数组 players ,其中 players[i] 表示第 i 名运动员的&n...

【题解】最大配对

题目描述      给出2个序列A={a[1],a[2],…,a[n]},B={b[1],b[2],…,b[n]},从A、B中各选出n个元素进行一一配对(可以不按照原来在...

【题解】金银岛

题目描述某天KID利用飞行器飞到了一个金银岛上,上面有许多珍贵的金属,KID虽然更喜欢各种宝石的艺术品,可是也不拒绝这样珍贵的金属。但是他只带着一个口袋,口袋至多只能装重量为w的物品。岛上金属有s个种...