【题目描述】
输入一个数,输出其素因子分解表达式。
【输入】
输入一个整数 n (2≤n<100)。
【输出】
输出该整数的因子分解表达式。
表达式中各个素数从小到大排列。
如果该整数可以分解出因子a的b次方,当b大于1时,写做 a^b ;当b等于1时,则直接写成a。
【输入样例】
60
【输出样例】
2^2*3*5
这题还是学到些东西的,首先递归,刚开始我写错了,这题应该是比较经典的题型,一开始我疑惑的是比如 连续除于2该如何实现这,我在main()写了循环求解,但是当时没想到,其实就是用个while(x%i==0){....}来去实现,那么这样的话直接在main()函数中写也就行了
再则这题用到了 桶排序的思想,可以把求的值当成下标,然后++判断有几个是数组的值,这个思想要时常想到
还有就是在输出的时候其实很简单 因为 i^s[i]是一个整体输出的,而不是我所想的是先输出i^ 在输出s[i],知道这个在控制输出不的时候就比较简单了,
其实桶排序的思想还有点和map的用法有点相似,就是map的下标可以为任意值,但是要注意的是map的键值是从小到大排序好的,所以要知道这点,这有对于有些题第一次出现的值而且这个还是键值,那么map就不好用了,那用桶排序比较好用了
其实这题的递归并不难,模拟循环的递归,一开始我想的比较难了,我在递归函数里写for(int i=2;i<=100;++i) 去判断了,然而这样的判断一般都是个很多层的判断,而且每层返回的递归,都是很多的,考虑起来还是比较难的,以为循环里递归每个i值都是会往下递归的,然后还是会遇见for,再则就是返回时这么多for的返回,当返回到最初的时候不知道在for循环里递归对了多少次了
#include<iostream>
#include<map>
#include<cstring>
#include<cstdio>
using namespace std;
int s[150];
void f(int x,int y)
{
if(x==0||y>x)
return;
else
{
while(x%y==0)
{
x/=y;
s[y]++;
}
f(x,y+1);
}
}
int main()
{
int n;
cin>>n;
f(n,2);
bool flag=false;
for(int i=2;i<=100;i++)
{
if(flag&&s[i])
cout<<"*";
if(s[i])
flag=true;
if(s[i]==1)
cout<<i;
else if(s[i]>1)
cout<<i<<"^"<<s[i];
}
return 0;
}