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

题目

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;
}
相关推荐
杨校1 分钟前
杨校老师课堂之C++高精度乘法
算法
上弦月-编程1 分钟前
C语言位运算:从入门到精通
运维·c语言·开发语言·vscode·算法·leetcode·极限编程
汉克老师2 分钟前
GESP2023年6月认证C++三级( 第三部分编程题(2、密码合规检测))
c++·字符串·gesp三级·gesp3级
钰珠AIOT13 分钟前
什么是句柄,有什么用?适用于什么场景?
c语言·c++
꧁细听勿语情꧂16 分钟前
用队列实现栈、用栈实现队列,树、二叉树、满二叉树、完全二叉树,堆、向下向上调整算法、出堆入堆、堆排序
c语言·开发语言·数据结构·算法
碧海银沙音频科技研究院18 分钟前
BES2800BP_nuttx编译环境搭建方法
人工智能·深度学习·算法
Felven28 分钟前
B. Make Almost Equal With Mod
数据结构·算法
脆皮炸鸡75529 分钟前
Linux~~基础IO
linux·运维·服务器·经验分享·算法·学习方法
众少成多积小致巨33 分钟前
Android 初始化语言入门
android·linux·c++
colofullove35 分钟前
文本分块策略与预处理
算法