位运算(1)
来源:互联网 发布:mysql as 规则 编辑:程序博客网 时间:2024/05/17 04:51
一提起位运算,人们往往想到它的高效性,无论是嵌入式编程还是优化系统的核心代码,适当的运用位运算总是一种迷人的手段,或者当您求职的时候,在代码中写入适当的位运算也会让您的程序增加一丝亮点,最初当我读《编程之美》求“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
如果您知道实用的一行位运算技巧请留言,博主不胜感激,还有我总结的位运算难免有不健壮之处,请您多多批评。
==================================================================================================
作者:nash_ 欢迎转载,与人分享是进步的源泉!
转载请保留原文地址:http://blog.csdn.net/nash_/article/details/8262185
========================================================================
a^b=c >> a=b^c
阅读全文
0 0
- 位运算(1)
- 位运算(1)
- 位运算总结(1)
- 位运算(1)-- 基础
- 位运算复习(1)
- 位运算(进阶篇1)
- 多少个1?(位运算)
- Pascal位运算基础(1)
- 二进制枚举例1(位运算)
- 位运算-1
- 位运算1
- 位运算妙用1
- 位运算实例1
- 位运算习题1
- 位运算1
- 位运算(1)
- 位运算(技巧)
- 位运算(2)
- 7/3作业:接口的作用:面向接口编程
- Python 高阶函数之 map()、reduce()、filter()
- 挖洞姿势:浅析命令注入漏洞
- 翻页功能的实现
- 微信小程序 调用支付jsapi时缺少参数:total_fee
- 位运算(1)
- 《数据库SQL实战》查找入职员工时间排名倒数第三的员工的所有信息
- 大明A+B 【java 处理高精度】
- 技能分享 | 麦肯锡教给我的写作武器:如何讲好一句话
- Java实现多线程的三种方式
- JQuery EasyUI的常用组件
- 在vs2013(vc12)上安装opencv
- POJ2559-Largest Rectangle in a Histogram
- Java基础(六)异常