质因数个数(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;
}
相关推荐
龚礼鹏6 分钟前
Android应用程序 c/c++ 崩溃排查流程二——AddressSanitizer工具使用
android·c语言·c++
Coovally AI模型快速验证8 分钟前
超越Sora的开源思路:如何用预训练组件高效训练你的视频扩散模型?(附训练代码)
人工智能·算法·yolo·计算机视觉·音视频·无人机
千金裘换酒15 分钟前
Leetcode 有效括号 栈
算法·leetcode·职场和发展
qq_4017004122 分钟前
QT C++ 好看的连击动画组件
开发语言·c++·qt
空空潍31 分钟前
hot100-最小覆盖字串(day12)
数据结构·算法·leetcode
Rui_Freely41 分钟前
Vins-Fusion之 相机—IMU在线标定(十一)
人工智能·算法·计算机视觉
yyy(十一月限定版)1 小时前
算法——二分
数据结构·算法
额呃呃1 小时前
STL内存分配器
开发语言·c++
七点半7701 小时前
c++基本内容
开发语言·c++·算法
嵌入式进阶行者1 小时前
【算法】基于滑动窗口的区间问题求解算法与实例:华为OD机考双机位A卷 - 最长的顺子
开发语言·c++·算法