• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Niro Einteson
文可提笔安天下 武可上马定乾坤
博客园    首页    新随笔    联系   管理    订阅  订阅

整数因子分解问题

整数因子分解问题

Time Limit: 1000 ms Memory Limit: 65536 KiB

Problem Description

大于1的正整数n可以分解为:n=x1*x2*…*xm。例如,当n=12 时,共有8 种不同的分解式:
12=12;
12=6*2;
12=4*3;
12=3*4;
12=3*2*2;
12=2*6;
12=2*3*2;
12=2*2*3。
对于给定的正整数n,计算n共有多少种不同的分解式。

Input

输入数据只有一行,有1个正整数n (1≤n≤2000000000)。

Output

将计算出的不同的分解式数输出。

Sample Input

12

Sample Output

8

Hint

 

Source

 

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 map<int,int> mp;
 4 int fun(int n){
 5     if(mp[n]) return mp[n];//如果这个数已经计算过了,可以直接返回
 6     if(n==1) return 1;
 7     int sum=1;//个数为1
 8     for(int i=2;i<=sqrt(n);i++){// 等于 sqrt(n);
 9         if(n%i==0){//需成为 因子 才可以继续计算
10              sum+=fun(i);
11              if(i!=n/i) sum+=fun(n/i);//若i== n/i 那么 只算一次,不相等,两边都算
12         }
13 
14     }
15     mp[n]=sum;//跟新mp[n]
16     return sum;
17 }
18 int main()
19 {
20     int n;
21     cin>>n;
22     cout<<fun(n)<<endl;
23     return  0;
24 }

 

posted @ 2019-11-25 19:58  Nirogo  阅读(1239)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3