1. 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);
}
時間太緊,沒注意程序的簡潔性和效率,這個需要你自己改了!
2. 尋找最大完全數 c語言
//應該是n以內的最大完全數
intmain()
{
intn,k,i,sum;
printf("請輸入一個正整數 ");
scanf("%d",&n);
printf("全部完全數為");
for(i=1;i<=n;i++)
{sum=0;//添加這一行就行了
for(k=1;k<i;k++)
{
if(i%k==0)
sum+=k;
}
if(sum==i)
printf("%d",i);
}
}
3. 用C語言:求完數
//因為沒有說明結束條件,所以暫且以范圍為輸入兩個0為結束條件
#include<stdio.h>
int check(int low, int high);//列印low和high范圍內的完數,並返回完數的個數
int test(int n);//檢測n是否為完數,如果是,則列印它,並返回1,否則,返回0.
int main(){
int low, high;
int count;//count變數為low和high范圍內的完數個數
scanf("%d%d", &low, &high);//輸入范圍
if(low>high || high>10000)//若不滿足要求的條件,退出程序
return (1);
while(low!=0 || high!=0)//low和high均為0,則結束
{
count=check(low, high);//列印low和high之間的完數,並返回個數給count
if(count==0)//如果完數個數為0,則列印no
printf("no");
printf("\n");
scanf("%d%d", &low, &high);//重新輸入范圍low和high
}
return 0;
}
int check(int low, int high){
int t=0;//t為發現的完數個數
int n;
for(n=low;n<=high;n++)
{
if(test(n)==1)
t++;
}
return t;//返回完數個數
}
int test(int n)
{
int i;
int sum=0;//sum為因子之和
for(i=1;i<=n/2;i++)
if(n%i==0)
sum=sum+i;
if(sum==n)
{
printf("%d ", n);//若n為完數,則列印,並返回1
return 1;
}
else//否則,返回0
{
return 0;
}
}
希望對你有用~~
4. 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;
}
5. 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變數加一,直到 結束
6. 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以內的完數演算法,供你參考
7. 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);
}
}
執行結果如下;
有疑問繼續追問;如解決您的問題,望採納;
8. 用C語言找出1000以內的完數。
用C語言輸出1000以內所有的完數步驟如下:
1、首先打開vc6.0,新建一個項目。
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);//調用這個函數
}