位运算技巧
来源:互联网 发布:广电总局禁止直播软件 编辑:程序博客网 时间:2024/06/05 01:12
一提起位运算,人们往往想到它的高效性,无论是嵌入式编程还是优化系统的核心代码,适当的运用位运算总是一种迷人的手段,或者当您求职的时候,在代码中写入适当的位运算也会让您的程序增加一丝亮点,最初当我读《编程之美》求“1的数目”时,我才开始觉得位运算是如此之美,后来读到 《Hacker's Delight》,感慨到Henry S.Warren把位运算运用的如此神出鬼没,很多程序都十分精妙,我觉得在一个普通的程序中大量运用这样的代码的人简直是疯了!但掌握简单的位运算技巧还是必要的,所以今天写这篇博文把我积累的一些位运算技巧分享给大家,这些技巧不会是如求“1的数目”的技巧,是最基本的一行位运算技巧!
Welcome To My BitTricks
1.获得int型最大值
另一种写法
另一种写法
C语言中不知道int占几个字节时候
2.获得int型最小值
另一种写法
3.获得long类型的最大值
C语言版
JAVA版
获得long最小值,和其他类型的最大值,最小值同理.
4.乘以2运算
5.除以2运算
6.乘以2的m次方
7.除以2的m次方
8.判断一个数的奇偶性
9.不用临时变量交换两个数(面试常考)
C语言版
通用版(一些语言中得分开写)
10.取绝对值(某些机器上,效率比n>0 ? n:-n 高)
11.取两个数的最大值(某些机器上,效率比a>b ? a:b高)
通用版
C语言版
12.取两个数的最小值(某些机器上,效率比a>b ? b:a高)
通用版
C语言版
13.判断符号是否相同
14.计算2的n次方
15.判断一个数是不是2的幂
16.对2的n次方取余
17.求两个整数的平均值
另一种写法
下面是三个最基本对二进制位的操作
18.从低位到高位,取n的第m位
19.从低位到高位.将n的第m位置1
20.从低位到高位,将n的第m位置0
另附一些对程序效率上没有实质提高的位运算技巧,一些也是位运算的常识(面试也许会遇到)
计算n+1
计算n-1
取相反数
另一种写法
if(x == a) x = b; if(x == b) x = a;
sign函数,参数为n,当n>0时候返回1,n<0时返回-1,n=0时返回0
阅读全文
0 0
- 位运算应用技巧
- 位运算应用技巧
- 位运算的技巧
- 位运算(技巧)
- 位运算各种技巧
- 位运算应用技巧
- 位运算常用技巧
- 位运算 技巧
- 位运算技巧
- 各种位运算技巧
- c++ 位运算 技巧
- 位运算技巧
- 位运算技巧
- 位运算技巧
- 位运算技巧
- 位运算技巧
- 位运算技巧总结
- 位运算技巧
- java集合类的讲解
- 微信小程序 chooseImage选择图片或者拍照
- 第六课 511遇见易语言大漠找字FindStrFastEx打多怪实例
- Android开发中Gradle的高级用法---productflavors, buildTypes
- Java8 Lambda表达式教程
- 位运算技巧
- 文章标题
- 1021
- 2017暑假集训总结
- php求三个数中间值
- make help收集
- win7 安装Redis
- C#基础-014 进位制转化
- SSM+Maven