解题思路:
首先,先找出该数的所有因子,
其次,判断该数是否为完数,
是:输出;不是:继续执行。
注意事项:
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语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:643 |
C语言程序设计教程(第三版)课后习题5.7 (C++代码)浏览:855 |
C语言训练-计算1977!* (C++代码)浏览:858 |
【回文数(二)】 (C语言代码)浏览:731 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:543 |
C语言程序设计教程(第三版)课后习题6.8 (C++代码)浏览:592 |
C语言训练-亲密数 (C语言代码)浏览:682 |
C语言训练-数字母 (C语言代码)浏览:608 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:561 |
1071题解浏览:493 |