#includestdio.h
站在用戶的角度思考問題,與客戶深入溝通,找到雞西梨樹網(wǎng)站設(shè)計(jì)與雞西梨樹網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名與空間、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋雞西梨樹地區(qū)。
int?main()
{
int?i,n,sum;
int?a,b;
scanf("%d%d",a,b);
for(n=a;n=b;n++)
{
sum=0;
for(i=1;in;i++)
{
if(n%i==0)
{sum=sum+i;}
}
if(sum==n)
{printf("%4d",n);}
}
return?0;
}
1、解題思路:所謂完數(shù)是一些特殊的自然數(shù)。如果一個(gè)數(shù)恰好等于它的因子之和,則稱該數(shù)為“完全數(shù)”。先定義一個(gè)函數(shù)用于判斷一個(gè)數(shù)是否是完數(shù),接著依次從2到5000依次循環(huán)判斷。
2、參考代碼:
#include?stdio.h
int?fun(int?n){//判斷n是否是完數(shù)?
int?i,sum=0;
for(i=1;in;i++)
if(n%i==0)?sum+=i;
if(sum==i)?return?1;
return?0;
}?
int?main?()
{
int?i;
for(i=2;i5000;i++)
if(fun(i))
printf("%d?",i);
return?0;?
}
3、運(yùn)行結(jié)果:6?28?496
#includestdio.h
int perfect(int a)
{
int i, s=0;
for (i = 1; i a; i++)
{
if (a%i == 0)
s = s + i;
}
return (s == a);
}
int main()
{
int i,n;
for (i = 2; i =1000; i++)
{
if (perfect(i))
printf("%5d", i);
}
}
完數(shù),即完全數(shù)(Perfect number),又稱完美數(shù)或完備數(shù),是一些特殊的自然數(shù)。其所有的真因子(即除了自身以外的約數(shù))的和(即因子函數(shù)),恰好等于本身。
根據(jù)該定義 可以得出判斷完數(shù)的函數(shù)如下:
#include?stdio.h
int?is_perfect_number(int?n)
{
int?i,s=0;
for(i?=?1;?i?=n/2;?i?++)
if(n%i?==?0)?s+=?i;//統(tǒng)計(jì)所有真因子的和。
if(s?==?n)?return?1;//如果與原值相等,則該數(shù)為完數(shù)。
return?0;//不是完數(shù)。
}
根據(jù)該函數(shù),只需要對需要打印的范圍內(nèi)所有數(shù)做遍歷,并逐一調(diào)用該函數(shù)判斷,如果返回1則打印即可。
void Solve(int num)
{
int sum = 0;
int i = 0;
if (num == 0)
{
printf("No\n");
}
else if (num == 1)
{
printf("Yes, its factors are %d\n", num);
}
else
{
for (i = 1; i num; i++)
{
if (num % i == 0)
{
sum += i;
}
}
if (sum == num)
{
printf("Yes, its factors are ");
for (i = 1; i num; i++)
{
if (num % i == 0)
{
printf("%d ", i);
}
}
printf("\n");
}
else
{
printf("No\n");
}
}
}
int main() //鏈表建立測試
{
int n;
while(scanf("%d", n) != EOF)
{
Solve(n);
fflush(stdin); //防止輸入字母造成死循環(huán)
}
return 0;
}
#includestdio.h
void main()
{
int i,t(0),m;
printf("請輸入一個(gè)數(shù):");
scnaf("%d",m);
for(i=1;im;i++)
{
if(m%i==0)
t=t+i;
}
if (t==m)
printf("該數(shù)是完數(shù)");
else
printf("該數(shù)不是完數(shù)");
}
分享名稱:完數(shù)用函數(shù)編寫c語言 完數(shù)c語言程序編寫
標(biāo)題路徑:http://muchs.cn/article42/hjohhc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、軟件開發(fā)、標(biāo)簽優(yōu)化、ChatGPT、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容