位运算判断奇偶


普通方法

public static boolean isOdd(int i){

        return i % 2 != 0;

}

位运算方法

public static boolean isOdd(int i){

        return (i & 1) != 0;

}

 

位运算可以提高程序的运行效率:

计算机中的数字通常用二进制补码表示——

如果为正数,补码与原码相同,直接看最后一位(因为数字1的前面N位均为0,跟它做与运算,前面肯定为0),奇数为1,偶数为0,与1相与,结果不变。

如果为负数,补码转原码:保持符号位不动,其它各位取反+1,即为负数的绝对值原码全部取反+1。还是看最后1位,先取反,再+1,结果还是和原来相同。进行与运算时还是原来的末位,所以用跟1做与运算还是保持原来的结果。

在C++中,可以使用位运算来判断一个数是奇数还是偶数。通常使用的位运算符是"与"运算符(&)和"等于"运算符(==)。通过将给定的数与1进行"与"运算,如果结果为0,则表示该数是偶数;如果结果为1,则表示该数是奇数。 以下是一个示例代码: ```cpp #include <iostream> using namespace std; int main() { int num; cout << "请输入一个整数:" << endl; cin >> num; if ((num & 1) == 0) { cout << "输入的数是偶数" << endl; } else { cout << "输入的数是奇数" << endl; } return 0; } ``` 在这个示例代码中,我们首先输入一个整数,然后使用位运算符"&"将该数与1进行运算。如果结果为0,则输出"输入的数是偶数";如果结果为1,则输出"输入的数是奇数"。这样就可以通过位运算来判断一个数是奇数还是偶数。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [C++中运算符优先级及位运算判断奇偶性](https://blog.csdn.net/secular_/article/details/85262491)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [C++ 使用位运算判断整数的奇偶性](https://blog.csdn.net/liu_feng_zi_/article/details/107974319)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值