c語言的完數,完數C語言程序

本文目錄一覽:

c語言 完全數

#includestdio.h

void main()

{

int i,n;

int s=0;

printf(“input a number N(1N=10000)\n”);

while(scanf(“%d”,n)!=1) //scanf的返回值是成功讀取的參數個數,輸入某個字符就退出循環了

{

s=0; //每次都要清零

for(i=1;i=n;i++)

if(n%i==0)

s=s+i;

if(s==n) //if/else語句應該放在while循環體內,每次循環都會讀入一個數,每個數都要作判斷

printf(“yes\n”);

else

printf(“no\n”);

}

}

用C語言求1000以內的完數?

完數,即完全數(Perfect number),又稱完美數或完備數,是一些特殊的自然數。其所有的真因子(即除了自身以外的約數)的和(即因子函數),恰好等於本身。

根據該定義 可以得出判斷完數的函數如下:

#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;//統計所有真因子的和。

if(s == n) return 1;//如果與原值相等,則該數為完數。

return 0;//不是完數。

}

根據該函數,只需要對需要打印的範圍內1 ~1000做遍歷,並逐一調用該函數判斷,如果返回1則打印即可。

完整代碼如下:

#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;//統計所有真因子的和。

if(s == n) return 1;//如果與原值相等,則該數為完數。

return 0;//不是完數。

}

int main()

{

int n;

for(n = 1; n 1000; n++)

if(is_perfect_number(n)) printf(“%d,”,n);

}

C語言中的完數是什麼意思

歐幾里德證明了:一個偶數是完數,當且僅當它具有如下形式:2^(p-1)*(2^p-1)

其中2^p-1是素數

完全數(Perfect number)是一些特殊的自然數:它所有的真因子(即除了本身以外的約數

)的和,恰好等於它本身。

例如:第一個完全數是6,它有約數1、2、3、6,除去它本身6外,其餘3個數相加,1+2+3

=6。第二個完全數是28,它有約數1、2、4、7、14、28,除去它本身28外,其餘5個數相加

,1+2+4 + 7 + 14=28。後面的數是496,8128。

古希臘數學家歐幾里德是通過 2^(n-1)*(2^n-1) 的表達式發現頭四個完全數的。

當 n = 2^1*(2^2-1) = 6

當 n = 2^2*(2^3-1) = 28

當 n = 2^4*(2^5-1) = 496

當 n = 2^6*(2^7-1) = 8128

歐幾里德證明了:一個偶數是完數,當且僅當它具有如下形式:2^(n-1)*(2^n -1)。

儘管沒有發現奇完數,但是當代數學家奧斯丁·歐爾(Oystein Ore)證明,若有奇完全

數,則其形狀必然是12p + 1或36p + 9的形式,其中p是素數。在1018以下的自然數中奇完

數是不存在的。

C語言求完數

/*完數,即完美數,一個數如果恰好等於除它本身外的因子之和,這個數就稱為完數。例如6=1+2+3.(6的因子是1,2,3)*/

#includestdio.h

void main()

{

int i,j,k,h,s,sum;

int a[200];//20個是不夠的

s=0;

sum=0;

for(i=2;i=1000;i++)

{

s=0;//此處s=0一定要加,因為前幾次循環的時候s的值已經改變

k=0;

for(j=1;ji;j++)

{

if((i%j)==0){a[k]=j;k++;}

}

for(h=0;hk;h++)

{

s+=a[h];

}

if(i==s){printf(“%d “,i);sum++;}

}

printf(“完數的個數:%d\n”,sum);

}

時間太緊,沒注意程序的簡潔性和效率,這個需要你自己改了!

c語言求解完數!

#includestdio.h

int main()

{

int i,j,sum=0;

int count=0;//計算完數的和

for(i=2;i1000;i++)

{

for(j=1;ji;j++)

{

if(i%j==0) sum=sum+j;

}

if(sum==i)

{

printf(“%d 是完數\n”,i);

count+=i;

}

sum=0;

}

printf(“完數和為: %d\n”,count);

return 0;

}

用C語言打印“完數”

完數,即完全數(Perfect number),又稱完美數或完備數,是一些特殊的自然數。其所有的真因子(即除了自身以外的約數)的和(即因子函數),恰好等於本身。

根據該定義 可以得出判斷完數的函數如下:

#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;//統計所有真因子的和。

    if(s == n) return 1;//如果與原值相等,則該數為完數。

    

    return 0;//不是完數。

}

根據該函數,只需要對需要打印的範圍內所有數做遍歷,並逐一調用該函數判斷,如果返回1則打印即可。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/285403.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 15:44
下一篇 2024-12-22 15:44

相關推薦

  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python購物車程序

    Python購物車程序是一款基於Python編程語言開發的程序,可以實現購物車的相關功能,包括商品的添加、購買、刪除、統計等。 一、添加商品 添加商品是購物車程序的基礎功能之一,用…

    編程 2025-04-29
  • 爬蟲是一種程序

    爬蟲是一種程序,用於自動獲取互聯網上的信息。本文將從如下多個方面對爬蟲的意義、運行方式、應用場景和技術要點等進行詳細的闡述。 一、爬蟲的意義 1、獲取信息:爬蟲可以自動獲取互聯網上…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • Vb運行程序的三種方法

    VB是一種非常實用的編程工具,它可以被用於開發各種不同的應用程序,從簡單的計算器到更複雜的商業軟件。在VB中,有許多不同的方法可以運行程序,包括編譯器、發布程序以及命令行。在本文中…

    編程 2025-04-29
  • Python一元二次方程求解程序

    本文將詳細闡述Python一元二次方程求解程序的相關知識,為讀者提供全面的程序設計思路和操作方法。 一、方程求解 首先,我們需要了解一元二次方程的求解方法。一元二次方程可以寫作: …

    編程 2025-04-29

發表回復

登錄後才能評論