首页 > 其他分享 >位运算应用

位运算应用

时间:2022-12-21 12:38:49浏览次数:37  
标签:pr 结点 20 运算 int 异或 应用


&与运算应用

位运算应用_位运算

按位或|

位运算应用_异或运算_02

异或运算^

位运算应用_结点_03


位运算应用_位运算的应用_04

取反运算~

位运算应用_结点_05

左移运算<<

位运算应用_位运算_06

右移运算>>

位运算应用_异或运算_07

无符号右移运算>>>

位运算应用_结点_08


负数以其正值的补码形式表示

位运算应用_位运算的应用_09


位运算应用_结点_10

位运算应用_结点_11

1.任何一个数和0异或是它的本身,和自身异或为0:
a^0=a a^a=0 利用上述性质,可以用来计算2个数的交换。大家应该知道,在计算机里,两个数互相交换,需要定义一个中间的变量来参与交换。如: int tmp; int a=10; int b=20; tmp=a; a=b; b=tmp; 上述代码计算之后,a和b的值完成交换,a的值为20,b的值为10。 如果用异或运算来交换2个数,可以如下方法: int a=10; int b=20; a=a^b; b=a^b; a=a^b; 上述运行之后,a和b依然完成了值的交换,但由于是异或位运算,所以效率比上面的代码要高。 证明:a=1020b=ab=(1020)20=102020=100=10a=ab=102010=101020=0^20=20把上述代码,可以封装为一个交换2个数的函数如下: void swap(int *a, int *b) { *a = *a ^ *b; *b = *a ^ *b; *a = *a ^ *b; }

2.将整数的第n位置位或清零:
#define BITN (1《n) 置位:a |= BITN; 清零:a &= ~BITN
3.清除整数a最右边的1。
方法:a & (a – 1)//该运算将会清除掉整数a二进制中最右边的1。 问题:如何判断判断整数x的二进制中含有多少个1? 分析:此题是微软公司的一道笔试题。下面用&运算来解决此题。 代码如下: int func(int x ) { int countx = 0; while ( x ) { countx++; x = x&(x-1); } return countx; }
4.用异或运算设计一个只有一个指针域的双向链表:

提示: 要实现该设计要求,需要记住链表的头结点和尾结点,并在链表结点的的next域存放前一个结点和后一个结点的异或值。即: p->next=pl^pr;//头结点的左边结点为NULL,尾结点的右边结点为NULL。 在遍历的时候,从头结点往右遍历的方法: pl=NULL;p=Head; while(p!=Tail) { pr=pl^(p->next); pl=p; p=pr; } 从尾结点往左遍历的方法: pr=NULL; p=Tail; while(p!=Tail){ pl=pr^(p->next); pr=p; p=pl; }
5.计算下面表达式的值
(char)(127<<1)+1(char)(-1>>1)+11<<2+3解答:(char)(127<<1)+1=(01111111<<1)+1=11111110+1=11111111=-1(char)(-1>>1)+1=(11111111>>1)+1=11111111+1=01<<2+3=1<<(2+3)=1<<5=2^5=32(注意《和+的优先级)



关于位运算的一点总结:
很久之前借了学校图书馆的一本叫做算法心得的书,看过之后感觉作者简直神奇,不愧是大师,里面是各种优化程序的奇淫技巧,不过那时什么都不懂,看了觉得没用,现在懂了一点了,然而之前看过的都忘了,里面关于位运算的内容特别多,值得一看。
下面就是一些常见的技巧,效率都比普通运算要高很多

/1、交换两个整数的值:int a, b;a = a ^ b;b = a ^ b;a = a ^ b;与下面的等价,不过利用的是^的重要性质,效率当然比算术运算高a = a + b;b = a - b;a = a - b;2、与2的x次方的运算int a;a <<= x;//乘2^xa >= x;//除2^xa & (1 << x) - 1 //取a%(2^x)的余数a & 1//判断奇偶性,为0则a为偶数,否则为奇数a & (a-1)//判断a是否为2的幂或者0,结果为0代表是,否则代表不是3、其他常用技巧int a, b;a = ~a + 1//取相反数a = (a ^ (a >> 31)) - (a >> 31) //取绝对值(a & b) + ((a ^ b) >> 1) //取平均值a ^ b//判断a、b符号是否相同,如果结果>0则相同,否则不同/

(1)、位运算优先级较低,如果结合其他的运算符,那么最好在使用时加上括号,当然如果很清楚优先级就另当别论了。
(2)、位运算虽说高效,但是很多枚举子集的技巧数据量大点就无法使用了,所以还是得慎用,根据题目的数据范围而定吧。
(3)、使用位运算注意细节的处理,比如说枚举子集时的起点,终点等等。
(4)、使用位运算关键是理解每一个运算的特点,灵活运用它们的性质,并且找到问题与位之间的联系,其实上面的几个枚举集合的技巧都是根据位之间的联系然后运用相应的运算符得出的,一些位运算符也有一些非常重要的特点,比如说异或运算具有交换律,结合律,自反性等等。
(5)、位运算应用很广,体现在很多算法和数据结构上,比如说状态压缩,树状数组等等,在状态压缩中的使用通常是最常见的,很多算法都设计到状态之间的转移,比如说搜索,dp等等。有时候很难表示当前的这个状态,但是通过二进制位便可以解决了,所以位运算还是很方便和实用的,比如说一些在棋盘,网格中要表示某一行/列的状态时的问题。
在数据结构中的应用最常见的是树状数组,借用论文上面的话:树状数组的思想核心在于运用了十进制数与二进制数之间的联系,通过数的二进制形式来决定储存信息,把复杂的问题简单化,方法简单巧妙。
树状数组的优势在于代码长度短,不易出错,思想巧妙,算法复杂度低,维护简单,易推广到二维甚至三维等等。对于数据结构要求操作不复杂的题目,是上佳的选择。
而且线段树也涉及到了简单的右移位运算,或运算等等。




标签:pr,结点,20,运算,int,异或,应用
From: https://blog.51cto.com/u_12606187/5959780

相关文章

  • Yum应用场景 之 基于Centos-7 内网yum源服务器同步公网yum源
    内网yum源服务器同步公网yum源​​前言​​​​一、Yum应用场景​​​​二、案例部署​​前言RHEL、Centos系列系统,安装软件需要搭建yum仓库。但是当我们安装某些大多数应用......
  • 互联网应用之传递HTTP参数
    实例说明HTTP是一种网络传输协议,现实中大多数网页都是通过"HTTP://www."的形式实现显示的.再具体应用时,一些需要的数据都是通过参数传递的.和网络HTTP有关的是HTTPproto......
  • T-SQL中的运算符
    --算数运算符SELECT3+4AS 加的结果GOSELECT5/2AS除的结果--2.5左右两边都是整数,结果是整数GOSELECT5.0/2AS除的结果 --两边......
  • 短路运算
    逻辑与&&的运算如果两边都为数字,或字符串数字,则返回右边的如果左边的值为【true】,不管右边的值是(真)是(假)都返回右边的如果左边的值为【false】,则都返回左边的,那......
  • 基于贝叶斯网(Bayes Netword)图模型的应用实践初探
    基于贝叶斯网(BayesNetword)图模型的应用实践初探1.贝叶斯网理论部分笔者在另一篇​​文章​​中对贝叶斯网的理论部分进行了总结,在本文中,我们重点......
  • 实验5 结构体应用编程
    实验任务三程序源码1#define_CRT_SECURE_NO_WARNINGS12#include<stdio.h>3#include<string.h>4#include<stdlib.h>5#defineN1006typedefstruct......
  • 直播预约通道开启!解锁音视频应用快速上线的秘诀
    音视频时代,如何一站式解决SDK兼容、联调、授权管理等问题?如何快速上线音视频应用?7月7日19:00-20:30,多位腾讯云音视频技术专家现身「新知·音视频技术公开课」直播间,分享......
  • Flask - 框架简介和第一个Flask应用程序
    一、前言菜鸡开始学习Flask框架了,参考:http://www.imooc.com/wiki/flasklesson/flaskintro.htmlPython比较主流的框架有:Flask,Django,FastApi,之前有简单了解过Djang......
  • 线段树复习笔记——综合应用(吉司机线段树)
    线段树的综合应用接下来,以洛谷P6242【模板】线段树3(超级毒瘤)为例,来看一下线段树的综合应用。先来看一下此题题意,很熟悉的题面:题目描述给出一个长度为\(n\)的数列......
  • OpenHarmony应用集成AGC认证服务实现登录
    11月4日在HDC大会(华为开发者大会2022)推出一套覆盖应用设计、开发、测试、上架、运营全生命周期的七大鸿蒙开发套件“金字塔”,本次分享内容围绕处于“塔尖”位置的一站式鸿......