1210:因子分解

【题目描述】

输入一个数,输出其素因子分解表达式。

【输入】

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

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值