位运算

数字用二进制表示后的运算

无论是有符号,无符号还是其他各种类型的数。它们之间的转换的基石就是二进制的表达式没有发生改变,变得只是转换的表达式。

1.简单的布尔运算 Boolean algebra

与&,或|,非~,异或^

与& 0 1
0 0 0
1 0 1
0 1
0 0 1
1 1 1
非 ~
0 1
1 0
异或 ^ 0 1
0 0 1
1 1 0

2.逻辑运算 logical operation

逻辑运算符 &&,||,!

记住这写运算只返回 ture or false ,也就是返回 0,1

例子 运算结果
!0x41 0x00
!0x00 0x01
0x69&&0x55 0x01

还有一个重要的性质

就是当第一个参数可以评估整个表达式的时候,这个时候结束返回,不需要再去评估第二个参数了

3.移位运算 shift operation

左移,left shift operation

右移,right shift operation :

  • 逻辑右移:直接进行移动填充0
  • 算术右移:填补most significant value ,也就是填充符号位

    00001010>>2=00000010

    10001010>>3=11110001

4.还需要注意的知识点

特别提醒:

  • 无符号数和有符号数之间的转换,或者是运算。要非常小心overflow
  • 可以使用移位运算来代替除法,移位运算的效率更高
  • 再就是一些需要积累的小技巧,例如 n&(n-1) 进行循环可以求出 n二进制表达式中的"1"的个数。

位运算的应用

剑指offer 面试题65:不用加减乘除做加法

分析的思路(三步走):

十进制分析 7+15

  • 第一步:各位进行相加(不进位) 5+7=2,0+1=1 结果为12
  • 第二步:做进位,5+7的进位值10
  • 第三步:累加前面的结果 12+10=22

二进制的分析 5(101)+17(10001)

  • 第一步: 各位进行相加,不进位
^ 异或
1 0 0 0 1
1 0 1
1 0 1 0 0
  • 第二步:做进位 与运算后,继续左移一个单位 才是进位值(iteration)
&
1 0 0 0 1
1 0 1
0 0 0 0 1
  • 第三步: 累加前面两步的结果 (可能需要继续进位)

10100+(00001<<1)00010=10110 在运算过程中无进位

代码实现

#include <cstdio>
int Add(int num1, int num2)
{
int sum, carry;
do {
sum = num1 ^ num2;
carry = (num1 & num2) << 1; // until carry=0 return sum(num1) num1 = sum;
num2 = carry;
}
while(num2 != 0);
return num1;
}

一些相关问题

交换两个变量的值(不使用中间变量temporary)

当然在python中可以直接进行交换,这个是语言的语法

a,b=b,a  # 可以直接实现元素之间的交换

基于加减法

int a,b;
a=a+b;
b=a-b; // b=((a+b)-b)=a
a=a-b; // a=((a+b)-a)=b

基于异或运算

a=a^b;
b=a^b; //b= (a^b)^b=a
a=a^b; //a= (a^b)^a=b

位运算总结(Bit Operation)的更多相关文章

  1. Java I/O : Bit Operation 位运算

    Writer      :BYSocket(泥沙砖瓦浆木匠) 微         博:BYSocket 豆         瓣:BYSocket FaceBook:BYSocket Twitter   ...

  2. CodeForces 282C(位运算)

    C. XOR and OR time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  3. uva 10718 Bit Mask (位运算)

    uva 10718  Bit Mask  (位运算) Problem A Bit Mask Time Limit 1 Second In bit-wise expression, mask is a ...

  4. A Corrupt Mayor's Performance Art(线段树区间更新+位运算,颜色段种类)

    A Corrupt Mayor's Performance Art Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 100000/100 ...

  5. POJ 2777 Count Color(线段树+位运算)

    题目链接:http://poj.org/problem?id=2777 Description Chosen Problem Solving and Program design as an opti ...

  6. A - Subarrays Beauty gym 位运算 &

    You are given an array a consisting of n integers. A subarray (l, r) from array a is defined as non- ...

  7. Codeforces 868D Huge Strings - 位运算 - 暴力

    You are given n strings s1, s2, ..., sn consisting of characters 0 and 1. m operations are performed ...

  8. HUST 1605 Gene recombination(广搜,位运算)

    题目描述 As a gene engineer of a gene engineering project, Enigma encountered a puzzle about gene recomb ...

  9. poj 2777 Count Color - 线段树 - 位运算优化

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 42472   Accepted: 12850 Description Cho ...

随机推荐

  1. 从后端到前端之Vue(五)小试路由

    一开始我还以为vue的路由只能用在工程化的项目里面呢,然后研究了一下才发现,在脚本化里面也是可以用的.其实呢不管在哪里用,把原理研究明白就对了. 一. 官网demo 这里不得不吐槽一下官网,写的不清不 ...

  2. MYSQL 时间轴数据 获取同一天数据的前3条

    创建表数据 CREATE TABLE `praise_info` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'ID', `pic_id` va ...

  3. web安全脑图

  4. MyBatis在Spring环境下的事务管理

    MyBatis的设计思想很简单,可以看做是对JDBC的一次封装,并提供强大的动态SQL映射功能.但是由于它本身也有一些缓存.事务管理等功能,所以实际使用中还是会碰到一些问题--另外,最近接触了JFin ...

  5. Linux升级GCC

    升级原因 测试需要使用DOClever,下载了最新的node8.11,运行node 时候报错 [root@app_test bin]# node www module.js:681 return pr ...

  6. AI中台——智能聊天机器人平台的架构与应用(分享实录)

    内容来源:宜信技术学院第3期技术沙龙-线上直播|AI中台——智能聊天机器人平台 主讲人:宜信科技中心AI中台团队负责人王东 导读:随着“中台”战略的提出,目前宜信中台建设在思想理念及架构设计上都已经取 ...

  7. 浅析java中的语法糖

    概述 编译器是一种计算机程序, 它主要的目的是将便于人编写.阅读.维护的高级计算机语言所写的源代码程序, 翻译为计算机能解读.运行的低阶机器语言的程序, 即可执行文件.而 javac 就是java语言 ...

  8. 【Java例题】5.5 两个字符串中最长公共子串

    5. 查找两个字符串中含有的最长字符数的公共子串. package chapter5; import java.util.Scanner; public class demo5 { public st ...

  9. 教老婆学Linux运维(一)初识Linux

    零.前言 之一 为什么写这个系列?为什么是Linux? 老婆自从怀孕以后,辞职在家待了好几年了,现在时常感觉与社会脱节.所以想找个工作. 做了多年程序员,有点人脉也都基本是在IT圈子里,只能帮忙找找I ...

  10. IntelliJ IDEA + Maven + Jetty + Jersey搭建RESTful服务

    这次参考的是这个博客,完全按照这个我这里会出一些问题,一会再说就是了. https://www.cnblogs.com/puyangsky/p/5368132.html 一.首先新建一个项目,选择Ja ...