程序员要知道的移位技巧
来源:互联网 发布:手机离线对讲机软件 编辑:程序博客网 时间:2024/06/14 11:42
一提起位运算,人们往往想到它的高效性,无论是嵌入式编程还是优化系统的核心代码,适当的运用位运算总是一种迷人的手段,或者当您求职的时候,在代码中写入适当的位运算也会让您的程序增加一丝亮点,最初当我读《编程之美》求“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
如果您知道实用的一行位运算技巧请留言,博主不胜感激,还有我总结的位运算难免有不健壮之处,请您多多批评。
转载原文地址:http://blog.csdn.net/nash_/article/details/8262185
阅读全文
0 0
- 程序员要知道的移位技巧
- 黑马程序员:移位运算符的注意事项及小技巧
- 程序员所知道的一些技巧
- 程序员需要知道的13个技巧
- 程序员要知道的
- 字符串移位的解题技巧
- 每个程序员都要知道的35个jQuery小技巧
- 程序员必须知道的SQLSERVER数据库优化技巧
- [转]程序员必须知道的SQLSERVER数据库优化技巧
- 程序员必须知道的SQLSERVER数据库优化技巧
- 程序员必须知道的SQLSERVER数据库优化技巧
- 程序员必须知道的SQLSERVER数据库优化技巧
- 程序员必须知道的SQLSERVER数据库优化技巧
- Java程序员应该知道的10个调试技巧
- Java程序员应该知道的10个调试技巧
- Java程序员应该知道的10个调试技巧
- Java程序员应该知道的10个调试技巧
- Java程序员应该知道的10个调试技巧
- HTML5自带的表单验证
- [设计模式]1. Template Method
- ssh 免密码登录设置后还是提示需要输入密码
- MTU,窗口大小和mss的区别
- Dijkstra模板[kuangbin]
- 程序员要知道的移位技巧
- 浅谈http返回码
- 微信开发怎么被动发送图文消息用户输入信息之后回复
- 在openStark框架中能用taskctl吗
- C++序列化
- intel caffe出现undefined symbol: mkl_sparse_d_csr__g_n_syrk_notr_row_struct_i8
- centos 优化 (内存等等)
- Docker部署基于Nodejs的Web应用-实战篇
- nfs搭建