標(biāo)題: c語(yǔ)言 (perfect number)既循環(huán)又判斷的程序 [打印本頁(yè)]

作者: liuda    時(shí)間: 2015-1-22 02:43
標(biāo)題: c語(yǔ)言 (perfect number)既循環(huán)又判斷的程序
//好記性不如爛筆頭,把腦子里想的落實(shí)到字面上來,有助于邏輯的推進(jìn)
//這個(gè)程序難在輸出因子那里,一次性全部因子搞出來

//find perfect number
//首先求出一個(gè)數(shù)的所有因子
//有for(i=1;i<=1000;i++)
//有if(i==(.+.+.+....))
//是因子就得被整除
//可以先降低難度只判斷某個(gè)數(shù)是不是完數(shù)
//首先判斷是不是因子,如果是就累加,接下來就是見證奇跡的時(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)在再來一次,把他的因子列出來不就行了
           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)又判斷的程序






歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1