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

题目

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;
}
相关推荐
踏浪无痕10 分钟前
周末拆解:QLExpress 如何做到不编译就能执行?
后端·算法·架构
一个不知名程序员www13 分钟前
算法学习入门--- 树(C++)
c++·算法
如竟没有火炬24 分钟前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
背心2块钱包邮37 分钟前
第9节——部分分式积分(Partial Fraction Decomposition)
人工智能·python·算法·机器学习·matplotlib
Simon席玉39 分钟前
C++的命名重整
开发语言·c++·华为·harmonyos·arkts
仰泳的熊猫39 分钟前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
chao18984439 分钟前
MATLAB中的多重网格算法与计算流体动力学
开发语言·算法·matlab
大工mike40 分钟前
代码随想录算法训练营第四十四天 | 99.岛屿数量 深搜 99.岛屿数量 广搜 100. 岛屿的最大面积
算法
十五年专注C++开发1 小时前
同一线程有两个boost::asio::io_context可以吗?
c++·boost·asio·异步编程·io_context
不穿格子的程序员1 小时前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy