您的位置:首页 > 其它

uva 10392(数学)

2014-07-18 19:14 218 查看
题解:从小到大循环分解输出相同的质数,范围到sqrt()。

#include <cstdio>
#include <cmath>
using namespace std;

int main() {
long long int n, temp;
int flag;
while (scanf("%lld", &n) && n > 0) {
temp = sqrt(n);
flag = 0;
for (long long int i = 2; i <= temp; i++)
while (n % i == 0) {
flag++;
n = n / i;
printf(" %lld\n", i);
}
if (flag != 0 && n != 1)
printf(" %lld\n", n);
if (flag == 0)
printf(" %lld\n", n);
printf("\n");
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  uva 数论