解题思路:
首先,先找出该数的所有因子,
其次,判断该数是否为完数,
是:输出;不是:继续执行。
注意事项:
number的初始化
i,j的作用域
参考代码:
#include int main() { int i,n,number; scanf("%d",&n); for (i = 6; i <= n ; i++) { // if (i % 10 != 6 && i % 10 != 8) //continue; //需要减少运行时间可加入此代码,跳过个位非6与8的数 //(完数规律:完数的个位必为6或8) number = 0; //由于要判断多个数是否为完数,故此要让其每次循环都执行一次初始化 for (int j = 1; j < i; j++) { if (i % j == 0) //找出所有的因子 number += j; } if (number == i) //判断i是否为完数 { printf("%d its factors are ", i); for (int j = 1; j < i; j++) { if (i % j == 0) printf("%d ", j); //输出后面的因子 } printf("\n"); } } return 0; }
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:1077 |
人民币问题 (C语言代码)浏览:1486 |
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:725 |
C语言程序设计教程(第三版)课后习题8.8 (C++代码)浏览:583 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:559 |
点我有惊喜!你懂得!浏览:2248 |
九宫重排 (C++代码)浏览:1410 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:606 |
WU-判定字符位置 (C++代码)浏览:1471 |
简单的a+b (C语言代码)浏览:457 |