pta找完数的两种方法

在大一的学习中,不少同学会在pta上做到老师安排的作业找完数,但是部分同学可能还不是特别精通C语言,下面是简单的两种方法。

#include <stdio.h>   
int main() 
{  
    int m, n;  
    int i, j;
    int s, p, flag = 0; // 定义三个整型变量s, p, flag。s用于存储数字i的所有因子的和,p用于存储某数字的累加和,flag表示完数,初始值为0  
    scanf("%d %d", &m, &n);  
      
    // 遍历m到n,检查这个范围内的每一个数是否为完数  
    for (i = m; i <= n; i++)  
    {  
        s = 0; // 在每次循环开始前,将s重置为0
        // 遍历1到i/2,用于找出数字i的所有因子  
        for (j = 1; j <= i / 2; j++)  
        {  
            // 如果j是i的因子(即i能被j整除)  
            if (i % j == 0)  
                // 将j加到s中,即把j作为数字i的一个正因子  
                s += j;  
        }  
          
        // 如果s等于i(i的所有因子的和等于i本身) 
        if (s == i)  
        {  
            flag = 1; // 设置flag为1,表示找到了一个完数  
            printf("%d = ", i); //
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值