题解 | 质数因子

质数因子

https://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607

#include <iostream>
#include <cstdio>
#include <string>
#include <algorithm>
#define int long long
using namespace std;

signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int n;
    cin >> n;
    for (int i = 2; i * i<= n; i ++) {
        while (n % i == 0) {
            cout << i << " ";
            n /= i;
        }
    }
    if(n >= 2) cout << n << " ";
    return 0;
}
// 64 位输出请用 printf("%lld")

写这道题的时候有点唐了,很简单。从最小的质数2开始,遍历就好,因为每次都是将最小的质因子除去了,所以不用担心会漏。用了埃式筛,可以缩小遍历的范围,同时特判剩下的n大于2的情况,防止缺最后一个质因子。#牛客春招刷题训练营#

#牛客春招刷题训练营##笔试#
全部评论
https://www.nowcoder.com/discuss/727521113110073344
点赞 回复 分享
发布于 03-20 12:34 山东

相关推荐

03-29 14:19
门头沟学院 Java
你背过凌晨4点的八股文么:加油同学,人生的容错率很高,只是一个暑期罢了,后面还有很多机会!
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务