本题要求实现一个函数,计算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;
}
/* 你的代码将被嵌在这里 */
输入样例:
6
2 -3 7 88 0 15
结尾无空行
输出样例:
Sum of ( -3 7 15 ) = 19
以下是我的解题思路
本题要求用 even 函数判断奇偶。我用 %2 的方法判断奇偶,即 n%2 的结果若是 0,就是偶数;若是 1,就是奇数。本题要求偶数返回 1,奇数返回 0,则用 if-else 函数判断并返回即可。
接下来是 Oddsum 函数,函数OddSum
负责计算并返回传入的N
个整数 List[]
中所有奇数的和。本题向 Oddsum 函数内传入了两个值,分别是数组 List[] 和 所有数的总数 N 。则考虑可以用 for 循环和题目内的 even(List[i]
) 将数组 List[]
内的所有奇数加在一起。
具体代码如下
int even( int n )
{
if( n%2==0 )
return 1;
else
return 0;
}
int OddSum( int List[], int N )
{
int sum = 0;
for(int i=0; i<N; i++)
{
if ( even(List[i])==0 )
sum = sum + List[i];
}
return sum;
}