完数!!!

题目:一个数如果恰好等于它的因子之和,这个数就称为“完数” 。例如 6=1+2+3.编程 找出 1000 以内的所有完数。


1. 程序分析:

         对 n进行分解质因数,应先找到一个最小的质数 k,然后按下述步骤完成: (1)如果这个质数恰等于 n,则说明分解质因数的过程已经结束,打印出即可。 (2)如果 n<>k,但 n 能被k 整除,则应打印出k 的值,并用 n 除以k 的商,作为新的正整数你 n, 重复执行第一步。 (3)如果 n不能被 k 整除,则用 k+1作为 k 的值,重复执行第一步。
 


2.程序源代码:

#include<stdio.h>
int main()
 {
	static int k[10];
	int i,j,n,s;
	for(j=2;j<1000;j++)
	{
		n=-1; 
		s=j;
		for(i=1;i<j;i++)
{
if((j%i)==0) 
{
	n++;
	s=s-i;
	k[n]=i;
 }
} 
		if(s==0)
		{ printf("%d is a wanshu",j);
		for(i=0;i<n;i++)
			printf("%d,",k[i]);
		printf("%d\n",k[n]);
		}
} 
}

3.代码及编译结果截图:


4.知识点:

          1、static 声明一个静态变量,标志着这个变量的生命周期和你的 程序一样长,你也可以理解为全局变量!

          2、[  ]下标运算符;

 

 

 

 

 

 

注:此文章用于个人学习,若有侵权请联系删除。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值