#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>=0){
if(n%2==0){
return 1;
}else{
return 0;
}
}else{
n=0-n;
if(n%2==0){
return 1;
}else{
return 0;
}
}
}
int OddSum(int list[],int N){
int sum=0;
int k;
for ( k=0; k<N; k++ ) {
if ( even(list[k])==0 )
sum+=list[k];
}
return sum;
}
本题要求实现一个函数,计算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
个人分析:
主要知识:
一.判断一个数的奇偶性
(一)、数学定义:
凡是可以被2整除的,称为偶数;否则为奇数。
1、C语言中最常用的判断方式:
根据定义,只需对2取余即可,所以可以通过取余运算符%,判断奇偶性。
要对整数n判断,则可以:
if(n%2==0) //可以整除为偶数
//这里判断可以写作 !(n%2) 等效。
2、最高效的判断方式:
计算机中都是以二进制存储,而判断是否可以被2整除,实际上只需要判断二进制最后一位即可。(&位运算符)
所以对整数n进行判断奇偶性可以写作:
if(n&1==0) //最低位为0,表示偶数。
//这里判断可以写作 !(n&1) 等效。
或
if(n&1==1) //最低位为1,表示奇数。
//这里判断也可以写作n&1,或者n&1!=0,都是等效的。
if((n&1)==0) //注意加括号
二、变量需要先定义后使用,for循环中的变量,需要在外面定义使用
三、负数求绝对值
#include<math.h>
这个头文件里面 包含有求绝对值的函数abs();
n=-n;