「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结构有所了解,我没记错的话也是路由映射的概念,需要进行配置. 其实前端这些框架的 ...
随机推荐
- RMQ、POJ3264
这里说几篇博客,建议从上到下看 https://blog.csdn.net/qq_31759205/article/details/75008659 https://blog.csdn.net/sgh ...
- 使用JDBC连接了数据库的图书管理系统2.0
更新日志: 2019.3.28 数据库版本2.0 1.使用mySQL数据库 2.修改代码使用JDBC连接数据库 3.新增Manage操作类及DBUtils数据库工具类 4.完善代码(封装及方法调用) ...
- 安装配置flutter环境
flutter 的中文文档 https://flutterchina.club/get-started/install/ github 地址 https://github.com/flutter/fl ...
- django笔记-url
本文章只是用于学习方面的笔记,方便以后避免重复掉坑. 1.模板template的html文件可以根据url.py文件配置的name查找对应的url 2.在template的html文件里里面的url就 ...
- PIE SDK矢量透明度、标注控制
1. 功能简介 透明度和标注是矢量图层的相关属性:图层透明值是0-100间的整数,标注是显示在地图上的文字信息,它是出图中不可或缺的重要元素.标注的样式丰富,并且放置位置灵活. 2. 功能实现说明 2 ...
- C#中Using里使用单例的问题
又给自己挖了一个坑跳进去. KafkaManager使用单例模型获取到一个producer,然而自己代码里用的时候加了一个using using (var producer = KafkaManage ...
- 0.数据结构(python语言) 基本概念 算法的代价及度量!!!
先看思维导图: *思维导图有点简陋,本着循循渐进的思想,这小节的知识大多只做了解即可. *重点在于算法的代价及度量!!!查找资料务必弄清楚. 零.四个基本概念 问题:一个具体的需求 问题实例:针对问题 ...
- 腾讯云CDB的AI技术实践:CDBTune
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:邢家树,高级工程师,目前就职于腾讯TEG基础架构部数据库团队.腾讯数据库技术团队维护MySQL内核分支TXSQL,100%兼容原生My ...
- ubuntu中mysql5.7表名区分大小写解决方案
在/etc/mysql/mysql.conf.d/mysqld.cnf 添加lower_case_table_names=1
- [转]NLog Layout Renderers ${}
https://github.com/nlog/NLog/wiki/Layout-Renderers Layout renderers are template macros that are use ...