本题要求实现一个函数,计算N个整数中所有奇数的和,同时实现一个判断奇偶性的函数。
函数接口定义:
int even( int n );
int OddSum( int List[], int N );
其中函数even
将根据用户传入的参数n
的奇偶性返回相应值:当n
为偶数时返回1,否则返回0。函数OddSum
负责计算并返回传入的N
个整数List[]
中所有奇数的和。
裁判测试程序样例:
#include <stdio.h>
#define MAXN 10
int even( int n );
int OddSum( int List[], int N );
int main()
{
int List[MAXN], N, i;
scanf("%d", &N);
printf("Sum of ( ");
for ( i=0; i<N; i++ ) {
scanf("%d", &List[i]);
if ( even(List[i])==0 )
printf("%d ", List[i]);
}
printf(") = %d\n", OddSum(List, N));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
输出样例:
参考代码:
int even(int n)//用于判断输入的数是否为奇数
{
if (n % 2 == 0)
return 1;
else
return 0;
}
int OddSum(int List[], int N)//用于将输入数组中的奇数相加并返回
{
int i;
int sum = 0;
for (i = 0; i < N; i++)
{
if (even(List[i]) == 0)//调用even()函数判断是否为奇数
sum += List[i];
}
return sum;
}
要判断一个整数n是否为奇数可以通过计算这个整数n除以2的余数来判断。
如果余数为1,即n=2k+1(k=0,1,2,...),为奇数;
如果余数为0,即n=2k(k=0,1,2,...),为偶数。
在OddSum()函数中,通过for循环遍历数组,利用enen()函数判断数组中每个元素的奇偶性。