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

题目

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 分钟前
线性dp-LIS题目3(合唱队形)
算法
weixin_467182282 分钟前
Arduino进阶二|自定义类库保姆级教程(从零手写属于自己的传感器类库+完整源码)
c语言·c++·单片机·嵌入式硬件·arduino·c++面向对象·diy库文件
小六学编程6 分钟前
二分查找详解:从普通二分到左右边界
算法·c/c++
wayz117 分钟前
Volume:PVO(百分比成交量震荡指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
毕竟是shy哥8 分钟前
PromptHash:基于亲和提示协同学习的自适应哈希检索跨模态算法
学习·算法·哈希算法
甄心爱学习8 分钟前
【项目实训(个人12)】
人工智能·python·算法
Highcharts.js15 分钟前
通过CSS变量实现图表色彩与逻辑解耦、图表主题统一|Highcharts Palette 详解
c++·echarts·highcharts·可视化开发·palette·styledmode·图表样式
玖玥拾20 分钟前
C/C++ 基础笔记(八)
c语言·c++
郝学胜_神的一滴31 分钟前
Qt 高级开发 027: QTabWidget自定义样式表美化实战
c++·qt
团象科技32 分钟前
走访近百支出海技术团队后的海外云计算资源选型实操观察
大数据·人工智能·算法