解题思路:
注意事项:因数不会超过这个数的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语言程序设计教程(第三版)课后习题10.1 (C语言代码)浏览:1449 |
买不到的数目 (C++代码)浏览:868 |
C语言程序设计教程(第三版)课后习题10.1 (Java代码)浏览:1447 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:881 |
C语言程序设计教程(第三版)课后习题6.9 (C语言代码)浏览:1007 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1312 |
WU-格式化数据输出 (C++代码)浏览:1212 |
WU-拆分位数 (C++代码)浏览:787 |
C语言程序设计教程(第三版)课后习题9.1 (C语言代码)浏览:546 |
逆反的01串 (C语言代码)浏览:1445 |