【问题描述】使用函数求合数和:输入两个正整数 m 和 n(1<=m<=n<=500),求 m 和 n 之间的合数和。合数指自然数中除能被1和本身整除外,还能被其他的数整除的数。1 既不是合数也不是素数,最小的合数是4 。要求定义并调用函数 composite(p)判 断 p 是否为合数,当 p 为合数时返回 1,否则返回 0。定义并调用函数 composite_sum(m, n),该函 数返回区间[m, n]内所有合数的和。
【输入形式】
【输出形式】
【样例输入】1 10
【样例输出】The sum of [1,10] = 37
【样例说明】
【评分标准】
#include<stdio.h>
int composite_sum(int p)
{ int i=2;
while(i<p)
{
if(p%i!=0)
i++;
else if(p%i==0)
{
return 1;
break;
}
return 0;
}
if(i>p)
return 0;
}
int main()
{ int a,b,i,j=0,sum;
int sum_[100];
scanf("%d %d",&a,&b);
for(i=a;i==b;i++)
{
composite_sum(i);
if(composite_sum(i)==1)
{
sum_[j]=i;
j++;
}
}
for(i=0;i==j;i++)
{
sum=sum+sum_[i];
}
printf("The sum of [1,10]=%d\n",sum);
return 0;
}