(笔记)两种判断奇数偶数的方法
来源:互联网 发布:一辈子买不起房子知乎 编辑:程序博客网 时间:2024/04/25 10:29
方法一、求余%
具体实现:
1、if( x % 2 )
// 奇数
else
具体实现:
1、if( x & 1 )
// 奇数
else
// 偶数
具体实现:
1、if( x % 2 )
// 奇数
else
// 偶数
2、(x%2)?奇数:偶数
方法二、与1相与 &1分析:
根据奇数偶数的定义,若整数除以2没有余数,则为偶数,否则为奇数。
因此,偶数取余结果为0,奇数取余结果为非零
在if(条件)判断中,若条件为非零,表示条件成立,否则表示条件不成立(即不执行if()之后的语句)
?:的情况类似
具体实现:
1、if( x & 1 )
// 奇数
else
// 偶数
2、(x&1)?奇数:偶数
分析:
首先得知道按位与运算&的使用方法
按位与运算 a&b
参与运算的两数各对应的二进位相与,只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:9&5可写算式如下:
先分别将两个数化为二进制,在进行运算
00001001 (9的二进制补码)
& 00000101 (5的二进制补码)
—————
00000001 (1的二进制补码)
可见9&5=1。
对于任何一个数 & 1,因为1的二进制是1,在它的补码中,除了最后一位为1,其它全部为0,前面提到,按位与运算&只有当两个数都为1时结果才是1,因此,任何一个数与1相与,只有最低位可能为1,因此最终的结果只有0和1两种情况,而且结果取决于另外那个数二进制中的最后一位(若为1,最终结果便为1,若为0,结果便是0)
从二进制化为十进制中,需要加上二进制中最低位乘以2的零次方(1*2^0或0*2^0),然后再加上 对应位乘以 2^1,2^2,2^3,2 ^4……但是之后这一些都数2的倍数,也就是都是偶数,要让这些偶数编程奇数,取决于 2^0这一项,即,一个十进制数字是奇数还是偶数,取决于二进制中最低位那个数是0还是1。
来自http://blog.csdn.net/u013162593/article/details/17473331
0 0
- (笔记)两种判断奇数偶数的方法
- (笔记)两种判断奇数偶数的方法
- Excel:5种判断奇数和偶数的方法
- 奇数和偶数的判断
- 另外一种高效地判断奇数和偶数的方法
- 三种分奇数偶数的方法
- 判断奇数偶数的时候用%而不是/
- 判断奇数偶数
- 判断奇数偶数
- 判断奇数和偶数
- 判断奇数偶数
- 判断奇数和偶数
- 判断奇数偶数
- 5.2奇数偶数判断
- 输出一个数的二进制数的奇数序列和偶数序列(三种方法)
- C语言 - 判断任意数的每位数是否为偶数【两种方法】
- c语言:两种方法判断1到100之间的奇数
- C语言中——三种方法判断是偶数还是奇数
- 15分钟学会使用Git和远程代码库
- syncronized深入
- 连接字符串
- Git 分支管理是一门艺术
- qt5连接sqlite数据库实例
- (笔记)两种判断奇数偶数的方法
- URI和URL的区别
- 介绍一个成功的 Git 分支模型
- Collection接口
- 地址描述符结构ARDS
- 坚持前进的方向:总结2013,规划2014
- hdoj1001解题报告
- ARM11处理器中的流水线级数增加研究
- 话说大数据时代