ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

分解质因数

2022-02-21 16:33:28  阅读:183  来源: 互联网

标签:输出 正整数 因数分解 int 因子 分解 质因数


hhhh,说来真惭愧

十分惭愧

特别惭愧

质因数分解我居然才学....脸红了一大截....我也是真牛逼了,才学质因数分解....hhh

学完再检讨,现在先看题...:

先解释一下吧:质因数:质因数(素因数或质因子)在数论里是指能整除给定正整数的质数。 除了1以外,两个没有其他共同质因子的正整数称为互质。 因为1没有质因子,1与任何正整数(包括1本身)都是互质。 正整数的因数分解可将正整数表示为一连串的质因子相乘,质因子如重复可以用指数表示。

简单来说啊,就是一个合数的因子是质数

然后那怎么分解呢

p=a1^n1*a2^n2*a3^n3...表达成这种形式比如36=2*2*3*3

代码如下:

#include<iostream>
using namespace std;
int main(){
    int n;
    cin>>n;//将n质因数分解'
    for(int i=2;i<=n;i++)
    {
        if(n%i==0)
        {
            int s=0;
            while(n%i==0)
            {
                s++;//指数,也就是有几个相乘
                n/=i; 
            }
            cout<<i<<" "<<s<<endl;
        }
    } 
    return 0;
    
}

并且循环里面的 i 一定是一个质数:假如 i 是一个合数,那么它一定可以分解成多个质因子相乘的形式,这多个质因子同时也是 a 的质因子且比 i 要小,而比 i 小的数在之前的循环过程中一定是被条件除完了的,所以 i 不可能是合数,只可能是质数(来自acw最高赞题解下面的一位大佬),我看完简直一目了然

然后对此代码进行优化:

在n中,最多只有一个质因子大于sqrt(n),如果有大于1个,那相乘必然比n要大,因此矛盾所以只有两个

先考虑比sqrt(n)小的,最后如果n还是>1,说明这就是大于sqrt(n)的唯一质因子,输出即可。

#include<iostream>
using namespace std;
int main(){
    int n;
    cin>>n;
    for(int i=2;i<=n/i;i++)
    {
        if(n%i==0)
        {
            int s=0;
            while(n%i==0)
            {
                s++;
                n/=i;
            }
            cout<<i<<" "<<s<<endl;
        } 
    }
    if(n>1) cout<<n<<" "<<1<<endl;
    return 0;
} 

上题目上题目:

给定 nn 个正整数 aiai,将每个数分解质因数,并按照质因数从小到大的顺序输出每个质因数的底数和指数。

输入格式

第一行包含整数 nn。

接下来 nn 行,每行包含一个正整数 aiai。

输出格式

对于每个正整数 aiai,按照从小到大的顺序输出其分解质因数后,每个质因数的底数和指数,每个底数和指数占一行。

每个正整数的质因数全部输出完毕后,输出一个空行。

数据范围

1≤n≤1001≤n≤100,
2≤ai≤2×1092≤ai≤2×109

输入样例:

2
6
8

输出样例:

2 1
3 1

2 3

 

#include<iostream>
using namespace std;
int main(){
    int n;
    cin>>n;
    while(n--)
    {
        int x;
        cin>>x;
        for(int i=2;i<=x/i;i++)
        {
            if(x%i==0)
            {
                int s=0;
                while(x%i==0)
                {
                    s++;
                    x/=i;
                }
                cout<<i<<" "<<s<<endl;
            }
        }
        if(x>1) cout<<x<<" "<<1<<endl;
        cout<<endl;
    }
    return 0;
}

 

标签:输出,正整数,因数分解,int,因子,分解,质因数
来源: https://www.cnblogs.com/ccwz7/p/15919462.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有