质因数个数(acwing,蓝桥杯)

题目描述:

给定正整数 n,请问有多少个质数是 n 的约数。

输入格式:

输入的第一行包含一个整数 n。

输出格式:

输出一个整数,表示 n 的质数约数个数。

数据范围:

对于 30% 的评测用例,1≤n≤10000。

对于 60% 的评测用例,1≤n≤1e9。

对于所有评测用例,1≤n≤1e16。

输入样例:

复制代码
396

输出样例:

复制代码
3

样例解释:

396 有 2,3,11 三个质数约数。

分析步骤:

第一:理清思路:

看到这个题目要求质因数个数,脑海中就应该立马出现试除法,线性筛,埃氏筛法....这一系列的方法,对于这道题目我们可以用试除法最简单了,因为试除法的时间复杂度为O(根号n)所以最大就是O(10^8)是可以算出来的。

第二:书写主函数,构建整体框架:

我们输入值,用for循环让i从2开始,因为2是最小的质因子,在判断一下i是否是n的约数,如果是的话,就计数器加加,再给他除干净,我们这么样处理的话我们就可以保证我们计数器每次加加都能是质因子。最终经过一系列的处理,如果i还是大于1的话就代表这个数也是质数还得加加。

最后输出就可以。

代码:

cpp 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;

typedef long long LL;

LL n;

int main()
{
    cin>>n;
    int res = 0 ;
    for(LL i = 2; i <= n / i; i ++){
        if(n % i == 0){
            res++;
            while(n % i == 0){
                n /= i;
            }
        }
    }
    if(n > 1) res++;
    cout<<res;
    
    return 0;
}
相关推荐
Darling噜啦啦11 分钟前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4562 小时前
C++进阶(1)——前景提要
c++
用户497863050733 小时前
(一)小红的数组操作
算法·编程语言
夜悊6 小时前
C++代码示例:进制数简单生成工具
c++
怕浪猫6 小时前
Electron 系列文章封面图
算法·架构·前端框架
郝学胜_神的一滴7 小时前
CMake 021: IF 条件判据详诠
c++·cmake
徐小夕8 小时前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
_wyt00121 小时前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
通信小呆呆1 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人