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

因子分解

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

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

【输入描述】
输入一个整数 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;
}


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

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

分享给朋友:
返回列表

上一篇:分数求和

下一篇:单词提取

相关文章

最大数max

【题目描述】已知:m=max(a,b,c)max(a+b,b,c)×max(a,b,b+c)m=max(a,b,c)max(a+b,b,c)×max(a,b,b+c)输入a,b,c,求m。把求三个数的...

【题解】最大平方因子

【题目描述】给定一个整数 n,请找出 n 的最大平方因子。所谓平方因子,就是一个 n 的因子,且是一个完全平方数。最大平方因子就是 n&nb...

【题解】阶乘问题

2.阶乘问题(fac.cpp)【题目描述】给定一个正整数n,求出一个最小的整数m并使得m!的末尾连续的0的个数小于n。m!=1*2*3*4*...*m【输入描述】第一行n。【输出描述】一个整数m。【样...

【题解】流感传染

【题目描述】有一批易感人群住在网格状的宿舍区内,宿舍区为n\*n的矩阵,每个格点为一个房间,房间里可能住人,也可能空着。在第一天,有些房间里的人得了流感,以后每天,得流感的人会使其邻居传染上流感,(已...

【题解】进制转换(2019青岛市程序设计竞赛)

【问题描述】输入十进制正整数n和k,输出n的k进制数。我们熟悉的十进制所需的10个基数(基本的数字符号)是0,1,2,3,4,5,6,7,8,9。当10<k<=16时,k进制的k个基数从小...

【题解】赢得比赛需要的最少训练时长

【题目描述】你正在参加一场比赛,给你两个 正 整数 initialEnergy 和 initialExperience 分别表示你的初始精力...