3个回答
展开全部
完全数是除自身外的所有因子之和与自身相等的数。用一个for循环检查2至1000的偶数(迄今为止发现的完数全是偶数),若符合条件则输出此数。检查时,用另一for循环计数变量从2开始步长为1至此数的一半去除此数,能整除的累加求和(1因子不用检查,直接计入和),最后与此数比较是否相等,相等的则是完数。代码如下:
#include "stdio.h"
int main(int argc,char *argv[]){
int n,k,s,t,sum;
for(sum=0,n=2;n<1000;n+=2){//遍历2~1000的偶数
for(s=1,t=(n>>1),k=2;k<=t;k++)//用2~n/2检查是否能整除
if(n%k==0)//将因子累加至s
s+=k;
if(n==s)//检查s是否与n自身相等
sum+=s;//完数累加到sum求和
}
printf("The sum of them is %d\n",sum);
return 0;
}
运行结果如下:
展开全部
根据题意可得代码:
#include <stdio.h>
int iswanshu(int a)
{
int sum = 0, i;
for (i = 1; i <= a/2; ++i){
if (a%i==0){
sum += i;
}
}
if (sum == a)return 1;
else return 0;
}
int fun()
{
int sum = 0, i;
for (i = 2; i <= 1000; ++i){
if (iswanshu(i)){
sum += i;
}
}
return sum;
}
int main()
{
int sum = fun();
printf ("%d\n", sum);
return 0;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int Cal(){
int i = 0,res = 0;
for(;i <= 1000;i++){
res += i;
}
return res;
}
int main(){
int res = 0;
res = Cal();
printf("result = %d\n",res);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询