「C基础」位运算
0. 原码、补码、反码
初学者只做了解即可 见 张子秋的博客
无论正负数,在内存中存储的都是补码
正数:反码 == 原码 == 补码
负数:反码 == ~原码
补码 == 反码+1
1. & 按位 与「AND」
功能:对应的两个二进位 均为1 时,结果 为1,否则 为0
例子:9&5 = 1001&0101 = 0001,即 9&5=1
*规律:二进制中与 1& 保持原位,与 0& 为0
2. | 按位 或「OR」
功能:对应的两个二进位 只要有一个为1 时,结果 为1,否则 为0
例子:9|5 = 1001|0101 = 1101,即 9|5=13
3. ^ 按位 异或「XOR,EOR」
功能:对应的两个二进位 不相同 为1,否则 为0
例子:9^5 = 1001^0101 = 1100,即 9^5=12
*规律:同一整数 相异或 为0, 例:5^5=0
不同整数 相异或 结果和顺序无关,例:5^6^7 = 5^7^6
任何数 和 0 异或 结果不变, 例:x^0 = x
综上,x^y^x = x^x^y = 0^y = y
4. ~ 按位 取反「NOR」
功能:对整数的 每一位取反,符号也位取反「取反:0取反为1,1取反为0」
例子:~9 = -10
5. << 左移
格式:整数<<左移个数
例子:x << n
实质:x * 2n
操作:把 x 的二进制位 向左移动 n 个单位,高位丢弃,低位补0
6. >> 右移
格式:整数>>右移个数
例子:x >> n
实质:x / 2n
操作:把 x 的二进制位 向右移动 n 个单位,低位丢弃,符号位不变
注意:符号位也跟着移动, 右移不改变整数的正负, 最后符号位要调整为原来的数值
正数 符号位为 0, 最高位补0
负数 符号位为 1, 最高位补1「取决于编译器的规定,这里以MAC的编译器为准」
7. 应用 「了解即可」
数值转换:
int a = ;
int b = ;
//1. 借助第三方变量
int temp;
temp = a;
a = b;
b = temp; //2. 不借助额外空间,数学方法
a = b - a;
b = b - a;
a = b + a; //3. 不借助额外空间,位运算
a = a ^ b;
b = a ^ b;
a = a ^ b;
奇偶判断:
int a=;
// 方法1 取模判断
// 注:这里由于 printf()是有返回值「输出的字符串长度」
// 所以可以用 三位运算符 条件?值:值
a%?printf(“奇数\n”):printf(“偶数\n”); // 方法2 与1判断
// 由于:奇数,二进制最后一位是 1
// 偶数,二进制最后一位是 0
// 1 & X = X的二进制最后一位
a&?printf(“奇数\n”):printf(“偶数\n”);
「C基础」位运算的更多相关文章
- C语言基础知识--位运算
1.原码,反码,补码: (1)在n位的机器数中,最高位为符号位,该位为零表示为正,为一表示为负:其余n-1位为数值位,各位的值可为零或一.当真值为正时,原码.反码.补码数值位 完全相同:当真值为负时, ...
- java基础之位运算
java中常见的位运算符:&(逻辑与) |(逻辑或) ~(取反) ^(逻辑异或) >>(右移) <<(左移) >>>(无符号右移) &(逻辑与 ...
- java ----> 基础之位运算
package test.ant; import java.util.Arrays; import java.io.UnsupportedEncodingException; public class ...
- day04-Python运维开发基础(位运算、代码块、流程控制)
# (7)位运算符: & | ^ << >> ~ var1 = 19 var2 = 15 # & 按位与 res = var1 & var2 " ...
- 黑马程序员_毕向东_Java基础视频教程——位运算练习(随笔)
位运算(练习) 最有效率的方式算出 2乘以 8等于几 2 << 3 = 2 * 2^3 = 2 * 8 = 16 对于两个整数变量的值进行互换(不需要第三方变量) class Test { ...
- 【LOJ】#2075. 「JSOI2016」位运算
题解 压的状态是一个二进制位,我们规定1到n的数字互不相同是从小到大,二进制位记录的是每一位和后一个数是否相等,第n位记录第n个数和原串是否相等,处理出50个转移矩阵然后相乘,再快速幂即可 代码 #i ...
- 【PHP基础】位运算与原码,反码,补码
对于有符号的而言: ①二进制的最高位是符号位: 0表示正数,1表示负数 ②正数的原码,反码,补码都一样 ③负数的反码=它的原码符号位不变,其它位取反(0->1,1->0) ...
- 2.2 Go语言基础之位运算操作
一.位运算符 位运算符对整数在内存中的二进制位进行操作. 运算符 描述 & 参与运算的两数各对应的二进位相与. (两位均为1才为1) | 参与运算的两数各对应的二进位相或. (两位有一个为1就 ...
- 「vue基础」一篇浅显易懂的 Vue 路由使用指南( Vue Router 上)
大家好,今天的内容,我将和大家一起聊聊 Vue 路由相关的知识,如果你以前做过服务端相关的开发,那你一定会对程序的URL结构有所了解,我没记错的话也是路由映射的概念,需要进行配置. 其实前端这些框架的 ...
随机推荐
- 移动端数据爬取(fidlde)
一.什么是Fiddler? 1 什么是Fiddler? Fiddler是位于客户端和服务器端的HTTP代理,也是目前最常用的http抓包工具之一 . 它能够记录客户端和服务器之间的所有 HTTP请求, ...
- JAVA 中 if和while的区别
while和if本身就用法不同,一个是循环语句,一个是判断语句. if 只做判断,判断一次之后,便不会再回来了while 的话,循环,直到结果为false,才跳出来 链表的结构,要一直读下去,直到读完 ...
- Js简易代码生成工具
代码 javascript:(function(){ document.body.innerHTML = '<textarea id="txtTemplate" style= ...
- JDBC的PreparedStatement启动事务使用批处理executeBatch()
JDBC使用MySQL处理大数据的时候,自然而然的想到要使用批处理, 普通的执行过程是:每处理一条数据,就访问一次数据库: 而批处理是:累积到一定数量,再一次性提交到数据库,减少了与数据库的交互次数, ...
- 使用Amoeba for mysql实现mysql读写分离(测试可行)
Amoeba for MySQL致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当query 路由功能,专注 分布式数据库 proxy 开发.座落与Client.DB S ...
- python词频统计
1.jieba 库 -中文分词库 words = jieba.lcut(str) --->列表,词语 count = {} for word in words: if len(word)==1 ...
- 05.if结构
分支结构:if if-else 选择结构:if else-if switch-case 循环结构:while do-while for foreach if语句 语法: if(判断条件) { //要 ...
- 【转载】BootStrap表格组件bootstrap table详解
(转载,来源“脚本之家”,作者不详) 一.Bootstrap Table的引入 关于Bootstrap Table的引入,一般来说还是两种方法: 1.直接下载源码,添加到项目里面来.由于Bootstr ...
- mysql忘记root密码的解决方法
Windows下mysql忘记root密码的解决方法 1. 首先检查mysql服务是否启动,若已启动则先将其停止服务,可在开始菜单的运行,使用命令:net stop mysql 或者在windows任 ...
- C# 读写xml、excel、word、ppt、access
C# 读写xml.excel.word.access 这里只是起个头,不做深入展开,方便以后用到参考 读写xml,主要使用.net 的xml下的document using System;using ...