當前位置:首頁 » 編程語言 » c語言完數

c語言完數

發布時間: 2022-01-14 06:13:10

A. 用c語言列印「完數」

// 本程序演示一個數如果恰好等於它的因子之和,這個數就稱為「完數」。例如6=1+2+3.編程找出1000以內的所有完數
#include"stdio.h"
main()
{
int i,j,s,sum;
printf("完數:\n") ;
sum=0;
for(i=2;i<=1000;i++)
{ s=0; ;//此處s=0一定要加,因為前幾次循環的時候s的值已經改變 。清零
for(j=1;j<i;j++)
{
if(i%j==0)//這一塊是如果能夠整除,那麼就是該數的因子,我們累加起來

{s+=j;
}
}
if(s==i) //因子的和與原數比較,如果正確就輸出
{printf("%d\n",i);
sum++;
}
}
printf("完數的個數:%d\n",sum);
}

B. C語言中關於完數問題

第一個空: return 1
第二個空: fun(x)

前幾天回答的時候,看到上樓的同志沒有第二個,我也就沒沒注意到第二個問題,希望沒耽誤你的事~~~

C. 完數 c語言

#include<stdio.h>

voidmain(){
inta[200];
intn,i,j,k,s;
for(n=1;n<=1000;n++){
j=0;
s=0;
for(i=1;i<=n/2;i++){
if((n%i)==0){
a[j]=i;
s+=i;
j++;
}
}
if(n==s){
printf("%d是完數,其因數是: ",n);
for(k=0;k<j;k++)
printf("%d",a[k]);
printf(" ");
}
}
}

D. c語言求解完數!

#include<stdio.h>
int main()
{
int i,j,sum=0;
int count=0;//計算完數的和
for(i=2;i<1000;i++)
{
for(j=1;j<i;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;
}

E. C語言如何判斷這個數是完數

1、打開c語言編輯器,新建一個C語言空白文件:

F. 用C語言輸出1000以內所有的完數

用C語言輸出1000以內所有的完數步驟如下:

1、首先打開vc6.0,新建一個項目。

G. 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以下的自然數中奇完
數是不存在的。

H. C語言 完數

#include<stdio.h>
void main()
{
int t, a=1,m=1;//a表示因子,sum表示因子和
while(m<1000)
{
int sum=0; //應該放在循環裡面,每次都要清0
for(a=1;a< m;a++) // 這里等號千萬不能要,要了它一定能整除,就會沒有結果
{
if(m%a==0)
{
t=a;
sum+=t;
}
}

if(sum ==m) //判斷應該在循環for循環外面
printf("%4d",m);
m++;

I. C語言:怎麼求完數

先定義一個數組a[]放各因數——一定有「1」
然後定義一個數組b[999]={1,2,3,4,5……}可以用for語句賦值int i,p;
for(i=0;i<=998;i++)
{for(p=1;p<=999;p++);
b[i]=p;}放1——999
然後用各各數——可再定義數組——去剩b[]
得余數為零的放到a[]再各各無素相加等於原來的剩數的,
就為真——用一個循環,一個int變數加一,直到 結束

熱點內容
玩qq三國要什麼樣的電腦配置 發布:2024-09-20 00:50:57 瀏覽:445
樹莓派zero編譯驅動 發布:2024-09-20 00:50:56 瀏覽:483
上傳文件文件夾找不到 發布:2024-09-20 00:26:32 瀏覽:915
承台箍筋加密區 發布:2024-09-20 00:26:31 瀏覽:228
筆記本什麼配置能流暢運行cf 發布:2024-09-20 00:14:19 瀏覽:952
實測華為編譯器 發布:2024-09-19 23:50:52 瀏覽:822
linux匯總 發布:2024-09-19 23:46:39 瀏覽:453
阿里雲伺服器環境搭建教程 發布:2024-09-19 23:21:58 瀏覽:837
黃色文件夾圖標 發布:2024-09-19 23:19:22 瀏覽:684
mysql資料庫導出導入 發布:2024-09-19 23:00:47 瀏覽:183