[题] 分解质因数 #质数(素数)

题目

AcWing 867. 分解质因数

题目大意:

输入:n个正整数。

输出:每个正整数的所有质因数以及其指数。

每处理一个正整数有一组输出,每组输出之间用一个空行隔开。


题解

原理:质数定理:n中最多只包含一个大于 sqrt(n)的质因子。

所以:在2~sqrt(n)种找到几乎所有的质因数,最后一个质因数就是除剩下的n。

操作:

  1. i从2开始枚举,只要满足i <= n / i,说明还有质因子没有除尽。
  2. 如果上面操作后若n有剩余,剩余的n就是那个大于sqrt(n)的质因子。

(时间O( log n ~ sprt(n) ))


代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
void divide(int n){
	//当i <= n/i 时,说明还没有遍历到重复的约数对
    for(int i = 2; i <= n / i; i ++){
        if(n % i == 0 && n){
            int cnt = 0;
            //将当前质因数除尽
            while(n % i == 0){
                n /= i;
                cnt ++;
            }
            cout << i <<' '<< cnt <<endl;
        }
    }
    //如果n还有剩余,那就是那个大于sqrt(n)的质因数
    if(n > 1) 
    	cout << n <<' ' << 1 << endl;
}

int main(){
    int n;
    cin >> n;
    while( n --){
        int q;
        cin >> q;
        divide(q);
        cout << endl;
    }
    return 0;
}
相关推荐
汽车仪器仪表相关领域13 分钟前
工况模拟精准检测,合规减排赋能行业 ——NHASM-1 型稳态工况法汽车排气检测系统项目实战经验分享
数据库·算法·单元测试·汽车·压力测试·可用性测试
L_090716 分钟前
【C++】高阶数据结构 -- 平衡二叉树(AVLTree)
数据结构·c++
今儿敲了吗17 分钟前
C++概述
c++·笔记
chilavert31823 分钟前
技术演进中的开发沉思-299 计算机原理:数据结构
算法·计算机原理
C+-C资深大佬31 分钟前
C++逻辑运算
开发语言·c++·算法
阿华hhh35 分钟前
项目(购物商城)
linux·服务器·c语言·c++
Qhumaing38 分钟前
C++学习:【PTA】数据结构 7-2 实验6-2(图-邻接表)
数据结构·c++·学习
天天进步201544 分钟前
KrillinAI 源码级深度拆解二:时间轴的艺术:深入 KrillinAI 的字幕对齐与音频切分算法
算法·音视频
爱编程的小吴1 小时前
【力扣练习题】121. 买卖股票的最佳时机
算法·leetcode·职场和发展
生信大杂烩1 小时前
空间转录组分析新工具 | MEcell:自适应微环境感知建模,精准解析细胞身份!
算法·数据分析