C语言 找出 1000 以内的所有完数

一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6的因子为1,2,3,而6=1+2+3,因此6是"完数",编程序找出1000以内的所有完数,并按下面格式输出其因子:6 its factors are 1,2,3

这个程序找出 1000 以内的所有完数,并输出每个完数及其因子。

(如果因子和等于该数,则该数为完数。)

cpp 复制代码
#include <stdio.h>

int main() {
    printf("1000 以内的所有完数及其因子:\n");

    for (int i = 1; i < 1000; i++) {
        int sum = 0;
        // 找出所有因子
        for (int j = 1; j <= i / 2; j++) {
            if (i % j == 0) {
                sum += j;
            }
        }
        // 判断是否为完数
        if (sum == i) {
            printf("%d its factors are", i);
            for (int j = 1; j <= i / 2; j++) {
                if (i % j == 0) {
                    printf(" %d", j);
                }
            }
            printf("\n");
        }
    }

    return 0;
}

代码说明

  1. 遍历 1 到 999 的每个数。
  2. 对每个数,找到所有因子并累加。
  3. 如果因子和等于该数,则输出该完数及其因子。
相关推荐
x_xbx12 分钟前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
weixin_3077791315 分钟前
OpenClaw-CN 安全增强方案:从理念到落地的全面剖析
开发语言·人工智能·算法·安全·语言模型
CoovallyAIHub16 分钟前
Agency-Agents(52k+ Stars):140+ 个角色模板,让 AI 编程助手变成一支专业团队
前端·算法·编程语言
范纹杉想快点毕业17 分钟前
C语言综合项目实战练手:基于C语言的简单数据库系统实现
服务器·c语言·数据库
nananaij17 分钟前
【LeetCode-05 好数对的数目 python解法】
python·算法·leetcode
季远迩23 分钟前
73.矩阵置零(中等)
算法
做一个码农都是奢望23 分钟前
计算机控制系统课程CH3:数字控制系统闭环响应分析与 MATLAB 实现
人工智能·算法·matlab
爱玩亚索的程序员30 分钟前
算法入门(三)学会用matplotlib画图
算法·matplotlib
一叶落43831 分钟前
LeetCode 6. Z 字形变换(C语言详解)
c语言·数据结构·算法·leetcode
啊董dong33 分钟前
noi-2026年3月17号作业
数据结构·c++·算法