浙大版《C语言程序设计(第4版)》题目集参考答案
本题要求实现一个函数,计算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
提交结果:
基本思路:
1.偶数的特点:能够被2所整除的整数,所以只要求余运算为0就是偶数,否则就是奇数;
2.接下来就是遍历数组,判断是否是奇数,求累加和。
代码实现:
int even(int n)
{
if (n % 2) //偶数对2的余数为0
{
return 0;
}else
{
return 1;
}
}
int OddSum(int List[], int N)
{
int OddSum = 0;//接收所有奇数的和
for (int i = 0; i < N; i++)//判断数组内的所有整数
{
if (even(List[i]) == 0)//利用函数的嵌套调用判断奇偶数
{
OddSum += List[i];//所有奇数的和
}
}
return OddSum;//返回结果
}
欢迎提问和纠错,共同讨论一起进步!