解题思路:
注意事项:因数不会超过这个数的1/2,想到这点可以优化运行时间。
参考代码:
#include <iostream>
using namespace std;
int main()
{
int M, N, i, j, sum=0;
cin>>N;
for(M=1;M<N;M++,sum=0)
{
for(i=1; i<=M/2; i++)
{
if(M%i==0) sum=sum+i;
}
if(sum==M)
{
cout<<M<<" its factors are ";
for(j=1;j<=M/2;j++)
if(M%j==0) cout<<j<<" ";
cout<<endl;;
}
}
}
0.0分
0 人评分
汽水瓶 (C++代码)(直接n/2就可以了)浏览:1138 |
矩形面积交 (C语言代码)浏览:1555 |
C语言程序设计教程(第三版)课后习题8.3 (Java代码)浏览:1402 |
P1002 (C语言代码)浏览:1021 |
输出正反三角形 (C语言代码)格式错误!!!浏览:1178 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1685 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:751 |
幸运数 (C++代码)浏览:1309 |
Minesweeper (C语言描述,蓝桥杯)浏览:1177 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:561 |