本题要求实现一个函数,计算 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
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/13/exam/problems/461
提交:
题解:
/*
* 判断奇偶性:偶 1 奇 0
*/
int even(int n) {
// return n % 2 == 0 ? 1 : 0;
return (n & 1) == 0 ? 1 : 0;
}
/*
* 返回传入的 N 个整数 List[] 中所有奇数的和
*/
int OddSum(int List[], int N) {
int oddSum = 0;
for (int j = 0; j < N; j++) {
if (even(List[j]) == 0) {
oddSum += List[j];
}
}
return oddSum;
}