OpenEdv-开源电子网

 找回密码
 立即注册

扫一扫,访问微社区

正点原子新作:阿波罗STM32F767&F429&探索者STM32F4开发板&赶快来下载资料哦。

查看: 289|回复: 2

[C语言作业提交] 输出完数例“6=1,2,3”

[复制链接]

  离线 

5

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-7-20
在线时间
19 小时
发表于 2017-7-24 13:37:13 | 显示全部楼层 |阅读模式
正点原子公众号
题目:
   3,一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如,6的因子为1,2,3,而6=1+2+3,因此6是完数。编程找出1000以内的所有完数,并输出到串口,输出格式为:“6=1,2,3” 。
   编程思路:
      首先定义一个数组,for循环找出每个数的因子存放数组中,然后判断这个数是否为完数,是完数就打印;
    我的代码:
    int main()
    {
        int m,n,i,sum,f,j;
        int b[10];
        Stm32_Clock_Init(9);       
        delay_init(72);                         
        uart_init(72,115200);        
        for(n=1;n<=1000;n++)
        {
                        f=0;
                        sum=0;
                        for(i=1;i<n;i++)
                        {
                                m=n%i;
                                if(m==0)
                                {
                                       
                                        b[f]=i;
                                        sum=sum+i;
                                        f++;
                                }       
                        }
                        if(n==sum)
                        {
                                printf("%d=%d",n,b[0]);
                                for(j=1;j<f;j++)
                                {
                                        printf("+%d",b[j]);
                                }
                                printf("\n");
                        }
          }
      }
            欢迎大家提出意见和指正,谢谢!
回复

使用道具 举报

  离线 

7

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-5-24
在线时间
23 小时
发表于 2017-7-29 10:11:59 | 显示全部楼层
回复 支持 反对

使用道具 举报

  离线 

5

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-7-20
在线时间
19 小时
 楼主| 发表于 2017-7-29 13:33:47 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则




QQ|联系我们|手机版|官方淘宝店|新浪微博|微信公众平台|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2017-11-20 05:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表
/* */