|
//好記性不如爛筆頭,把腦子里想的落實(shí)到字面上來(lái),有助于邏輯的推進(jìn)
//這個(gè)程序難在輸出因子那里,一次性全部因子搞出來(lái)
//find perfect number
//首先求出一個(gè)數(shù)的所有因子
//有for(i=1;i<=1000;i++)
//有if(i==(.+.+.+....))
//是因子就得被整除
//可以先降低難度只判斷某個(gè)數(shù)是不是完數(shù)
//首先判斷是不是因子,如果是就累加,接下來(lái)就是見證奇跡的時(shí)刻
#include<stdio.h>
void main()
{
//首先得輸入一個(gè)整數(shù)吧,然后還有因子的和
int i,sum=0,j;
//printf("please input an integer:\n");
// scanf("%d",&i);
//從1開始判斷,用j當(dāng)做待判斷數(shù)
for(i=1;i<=1000;i++)
{
for(j=1;j<i;j++)
{
if(i%j==0)
sum=sum+j;
}
if(i==sum)
{ printf("%d its facters are ",i);
//我的想法是到這里以后既然i是完數(shù)了,那么現(xiàn)在再來(lái)一次,把他的因子列出來(lái)不就行了
for(j=1;j<i;j++)
{
if(i%j==0)
printf("%d,",j);
}
printf("\n");
}
sum=0;//這個(gè)累加數(shù)在循環(huán)后要清零,這個(gè)很常用
}
//判斷的任務(wù)完成后就是for(i=1;i<=1000;i++)
}
//這是一個(gè)既循環(huán)又判斷的程序
|
|