此题通过从2开始去找数n的质因数,用例输入2000000014过不了,因为2000000014的质因数为2和1000000007,后面是一个非常大的素数,在for循环中就相当于直接遍历1000000007了,会超时。通过引入判断是否为素数来进行优化。素数的判断也是经过了优化的,参考我的另一篇文章《利用孪生素数判断是否为素数》,地址:https://blog.nowcoder.net/n/52c9640ea14a4330a842e783429698b5

#include <stdio.h>
#include <stack>
#include <math.h>

using namespace std;

bool is_prime(long n)
{
    if(n==2 || n==3) return false;
    if(n%6!=1 && n%6!=5) return false;

    //到这里,留下来的n只可能是6N+1或者6N+5;
    long div = 5;
    long t = n/div;
    while(t>=div)
    {
        //n可能是(6N+1)与(6N+5)两个因子的乘积,故需要在这里进行判断;
        if(n%div==0 || n%(div+2)==0) return false;
        div += 6;
        t = n/div;
    }
    return true;
}

void fun(long n)
{
    for(long i=2;i<=n;i++)
    {
        //用例输入2000000014过不了,这里通过判断是否为素数来提前结束;
        if(is_prime(n))
        {
            printf("%ld",n);
            return;
        }

        while(n % i == 0)
        {
            printf("%d ",i);
            n /= i;


        }
    }
}

int main()
{
    long n;
    while(scanf("%ld",&n) != EOF)
    {
        fun(n);
    }
    return 0;
}