1. 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;
}
2. C語言求完全數
#include"stdio.h"
intmain(void)
{
inta,b,sum=0;
for(a=6;a<1000;a++){
sum=0;
for(b=a-1;b>=1;b--)
{
if(a%b==0)sum=sum+b;
}
if(sum==a)
printf("%-4d的因數之和是%d ",a,sum);
}
}
執行結果如下;
有疑問繼續追問;如解決您的問題,望採納;
3. 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以內的完數演算法,供你參考
4. C語言求完數
/*完數,即完美數,一個數如果恰好等於除它本身外的因子之和,這個數就稱為完數。例如6=1+2+3.(6的因子是1,2,3)*/
#include<stdio.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;j<i;j++)
{
if((i%j)==0){a[k]=j;k++;}
}
for(h=0;h<k;h++)
{
s+=a[h];
}
if(i==s){printf("%d ",i);sum++;}
}
printf("完數的個數:%d\n",sum);
}
時間太緊,沒注意程序的簡潔性和效率,這個需要你自己改了!
5. c語言求完全數
完全數,又稱完美數, 是一些特殊的自然數。它所有的真因子(即除了自身以外的約數的和(即因子函數),恰好等於它本身。如果一個數恰好等於它的真因子之和,則稱該數為「完全數」。第一個完全數是6,6=1 2 3=1+2+3.
6. 如何用 C/C++ 求 1 到 1000 內的所有完全數
用 C/C++求1到1000內的所有完全數:
voidWS(int);
voidmain();
intn;
for(n=1;n<=1000;n++);
WS(n);
voidWS(intm);
{inti,sum=0;
for(i=1;i<m;i++);
if(m%i==0);
sum=sum+i;
if(sum==m);
printf(" 完數為%d=",m);
intj;
for(j=1;j<m;j++);
if(m%j==0);
printf("%d",j)。
定義
如果一個數恰好等於它的真因子之和,則稱該數為「完全數」。各個小於它的約數的和等於它本身的自然數叫做完全數,又稱完美數或完備數。例如:第一個完全數是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。
7. c語言編寫程序:求出1-100之間的完全數.所謂完全數是指這樣的數,該數剛好等於
#include<stdio.h>
#defineMAX100/*100以內的完全數*/
intmain(void){
intx,temp,sum;/*X表示要判斷的數,temp表示數的因子,sum表示因子之和*/
for(x=1;x<=MAX;x++){
sum=0;
for(temp=1;temp<x;temp++){/*判斷x能否被temp整除,如果可以,則是因子,進行求和*/
if(x%temp==0)
sum=sum+temp;
}
if(sum==x)/*如果是完數,列印輸出*/
printf("%d ",x);
}
putchar(' ');
fflush(stdin);
getch();
return0;
}
運行結果
8. 用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;
}
9. C語言求完全數~~
#include<stdio.h>
void isPerfect(int m){ //定義判斷一個數是否為完全數的函數isPerfect
int i,sum=0;
for(i=1;i<=m/2;i++){
if(m%i==0){
sum+=i;
}
}
if(sum==m){
printf("你輸入的這個數是完全數\n");
}
else
printf("你輸入的這個數不是完全數\n");
}
main(){
int a;
printf("請輸入一個整數a:\n");
scanf("%d",&a);
isPerfect(a);//調用這個函數
}
10. 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;
}