质数因子

来源:互联网 发布:手机动漫制作软件 编辑:程序博客网 时间:2024/05/24 05:15

题目描述

功能:输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )

最后一个数后面也要有空格

详细描述:


函数接口说明:

public String getResult(long ulDataInput)

输入参数:

long ulDataInput:输入的正整数

返回值:

String

输入描述:

输入一个long型整数

输出描述:

按照从小到大的顺序输出它的所有质数的因子,以空格隔开。最后一个数后面也要有空格。

示例1

输入

180

输出

2 2 3 3 5
我的代码:
#include<stdio.h>
#include<iostream>
using namespace std;
class QualityFactor  //质因数
{
private:
    int n;
public:
    void QFContract(long a) //用短除法对合数进行分解
    {
        n = 0; //初始化
        
        while(a>1)
        {
            for(int i=2;i<=a;i++)
            {
                if(a%i==0) //短除法  i是因数
                {
                    a = a/i;         //另一个余数
                    cout << i << ' '; //输出因子
                    break;
                }
            }
        }
        cout << endl;
    }
    
    
};
int main()
    {
    int num;
    cin>>num;
    //先求因数,再求因数里的质数,也就是素数
    QualityFactor QF;
    QF.QFContract(num);
    system("pause");
    return 0;
}
















原创粉丝点击