解题思路:
注意事项:因数不会超过这个数的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语言训练-求具有abcd=(ab+cd)2性质的四位数 (C语言代码)浏览:1367 |
C语言训练-谁家孩子跑最慢* (C语言代码)浏览:1507 |
K-进制数 (C++代码)浏览:850 |
C语言程序设计教程(第三版)课后习题10.7 (C语言代码)浏览:958 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:604 |
本人酷爱递归实现很多问题,这里也是浏览:549 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:470 |
WU-输出九九乘法表 (C++代码)浏览:1661 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)from DQM浏览:653 |
愚蠢的摄影师 (C++代码)浏览:934 |