#include <iostream> using namespace std; int main() { int n; cin >> n; for (int i = 6; i <= n; i++)//遍历6-n的所有情况,因为题意最小的可能为6,可直接省略1-5 { int sum = 0;//用来求所有因子之和 for (int j = 1; j < i; j++)//用for循环遍历,求出所有的因子 { if (i % j == 0)//判断是否为因子,如果是,累加 { sum += j; } } if (sum == i) { printf("%d its factors are ", i); for (int k = 1; k < i; k++)//与上一循环相似,上一个j循环求因子和,该循环判断出因子直接输出 { if (i % k == 0) cout << k << ' '; } cout << endl; } } return 0; }
解题思路:
注意事项:许多花括号都可以去掉
参考代码:
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:599 |
汽水瓶 (C语言代码)浏览:706 |
上车人数 (C语言代码)浏览:783 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:877 |
简单的a+b (C语言代码)浏览:701 |
校门外的树 (C语言代码)浏览:961 |
C语言训练-求函数值 (C语言代码)浏览:582 |
WU-蓝桥杯算法提高VIP-企业奖金发放 (C++代码)浏览:1176 |
简单的a+b (C语言代码)浏览:636 |
C语言程序设计教程(第三版)课后习题8.6 (C语言代码)浏览:568 |