當前位置:首頁 » 編程語言 » c語言求完全數怎麼說
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言求完全數怎麼說

發布時間: 2022-04-03 13:18:40

1. c語言求完美數

判斷完一個i是否是完數後,sum沒有及時賦值為0,而是一直累加下去,當然就找不到完數了。

#include<stdio.h>
intmain()
{
inti,j;
intsum=0;
for(i=1;i<=100;i++)
{
for(j=1;j<i;j++)
{
if(i%j==0)sum+=j;
}
if(sum==i)
{
printf("%d",i);
}
sum=0;//sum重新賦值0,以便求下一個i的因數和
}
return0;
}

運行結果:

2. C語言、完全數

說明還在循環中,一直在尋找。
雙層循環最後循環變數越大,越慢了。

3. 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變數加一,直到 結束

4. C語言計算1000以內的完全數

if (m=0)錯了
應該為if (m==0)

5. 用C語言求完數

//有三個,6,28,496
#include<stdio.h>
void main()
{
int i,j,k,sum;
for(i=1;i<=1000;i++)
{
sum=0;
for(j=1;j<=i/2;j++)
if(i%j==0) sum+=j;

if(sum==i)
{
printf("%d\t的因子是:",i);
for(j=1;j<=i/2;j++)
if(i%j==0) printf("%d ",j);

printf("\n");
}
}
return;
}

6. C語言求 1000以內的完全數

重置sum的位置錯了,放到內循環的開頭:

#include<stdio.h>
intwanquanshu()
{
intn,i,k,sum;
while(scanf("%d",&n)!=EOF)
{
for(i=1;i<=n;i++)
{
sum=0;//放在這里
for(k=1;k<i;k++)
{

if(i%k==0)
{
sum=sum+k;
}
}
if(sum==i)
{
printf("%d ",i);
}
}
}
return0;
}
voidmain()
{
wanquanshu();
}

7. c語言中求完全數

#include <stdio.h>
#include <math.h>
int main()
{
int a,i;
for(a=1;a<=1000;a++){
int A[100]={0},j;
j=0;
for(i=1;i<a;i++){ //i<sqrt(a) ——》並不是判定質數,需要找出除本身外所有因數
if(a%i==0){ //a/i==0 ——》/是求商,%才是取余
A[j]=i; //A[j]=a ——》A[j]應存儲的是a的因數,而不是它本身
j++;
}
}
int n,b;
n=j;
b=a;
for(j=j-1;j>=0;j--){
b=b-A[j];
}
if(b==0){
printf("%d=",a);
for(j=0;j<n-1;j++){
printf("%d+",A[j]);
}
printf("%d\n",A[j]);
}
}
return 0;
}

8. C語言求完數

#include <stdio.h>

int ws(int a,int b,int c)
{
int d;
if (a>c) {
if (a%c==0)
b+=c;
d=ws(a,b,c+1);
}
else if (c==a) {
if (b==a) {
return 1;
}
else return 0;
}
if (c==a-1&&d) {
printf("%d is Prefect number:\t",a);

}
if (d&&(a%c==0)) {
printf("%d ",c);
}
else if (!d) return 0;
if (c==1)
{putchar('\n');
return d;}

}
int main(void)
{
int i;

for (i=1; i<=1000; i++)
ws(i,0,1) ;
return 0;
}
這里舉例了一個求1000以內的完數演算法,供你參考

9. C語言編程:求出1000以內的完全數(詳細講解一下思路)

#include<stdio.h>
main()
{
int i,j,sum;
for(i=2;i<1000;i++) //完全數i的范圍2-1000
{
sum=0;
for(j=1;j<=i/2;j++) //求i的因子,j<=i/2為了減少循環次數
{
if(i%j==0) //如果i除以j的余數為0,就說明是因子
sum=sum+j;//求因子的和
}
if(sum==i) //如果因子等於i,就說明是完全數
printf("%4d",i); //輸出i
}
}

10. c語言編程 求完全數

說錯了
,sum=0;將和重新置1應該是重新置0
已經通過編譯的。