`

位运算应用口诀和实例

    博客分类:
  • java
 
阅读更多

位运算应用口诀
清零取反要用与,某位置一可用或
若要取反和交换,轻轻松松用异或
移位运算
要点 1 它们都是双目运算符,两个运算分量都是整形,结果也是整形。
2 " < <" 左移:右边空出的位上补0,左边的位将从字头挤掉,其值相当于乘2。
3 ">>"右移:右边的位被挤掉。对于左边移出的空位,如果是正数则空位补0,若为负数,可能补0或补1,这取决于所用的计算机系统。
4 ">>>"运算符,右边的位被挤掉,对于左边移出的空位一概补上0。
位运算符的应用 (源操作数s 掩码mask)
(1) 按位与-- &
1 清零特定位 (mask中特定位置0,其它位为1,s=s&mask)
2 取某数中指定位 (mask中特定位置1,其它位为0,s=s&mask)
(2) 按位或-- |
常用来将源操作数某些位置1,其它位不变。 (mask中特定位置1,其它位为0 s=s|mask)
(3) 位异或-- ^
1 使特定位的值取反 (mask中特定位置1,其它位为0 s=s^mask)
2 不引入第三变量,交换两个变量的值 (设 a=a1,b=b1)
目 标 操 作 操作后状态
a=a1^b1 a=a^b a=a1^b1,b=b1
b=a1^b1^b1 b=a^b a=a1^b1,b=a1
a=b1^a1^a1 a=a^b a=b1,b=a1
二进制补码运算公式:
-x = ~x + 1 = ~(x-1)
~x = -x-1
-(~x) = x+1
~(-x) = x-1
x+y = x - ~y - 1 = (x|y)+(x&y)
x-y = x + ~y + 1 = (x|~y)-(~x&y)
x^y = (x|y)-(x&y)
x|y = (x&~y)+y
x&y = (~x|y)-~x
x==y: ~(x-y|y-x)
x!=y: x-y|y-x
x < y: (x-y)^((x^y)&((x-y)^x))
x <=y: (x|~y)&((x^y)|~(y-x))
x < y: (~x&y)|((~x|y)&(x-y))//无符号x,y比较
x <=y: (~x|y)&((x^y)|~(y-x))//无符号x,y比较
应用举例
(1) 判断int型变量a是奇数还是偶数
a&1 = 0 偶数
a&1 = 1 奇数
(2) 取int型变量a的第k位 (k=0,1,2……sizeof(int)),即a>>k&1
(3) 将int型变量a的第k位清0,即a=a&~(1 < <k)
(4) 将int型变量a的第k位置1, 即a=a|(1 < <k)
(5) int型变量循环左移k次,即a=a < <k|a>>16-k (设sizeof(int)=16)
(6) int型变量a循环右移k次,即a=a>>k|a < <16-k (设sizeof(int)=16)
(7)整数的平均值
对于两个整数x,y,如果用 (x+y)/2 求平均值,会产生溢出,因为 x+y 可能会大于INT_MAX,但是我们知道它们的平均值是肯定不会溢出的,我们用如下算法:
int average(int x, int y) //返回X,Y 的平均值
{
return (x&y)+((x^y)>>1);
}
(8)判断一个整数是不是2的幂,对于一个数 x >= 0,判断他是不是2的幂
boolean power2(int x)
{
return ((x&(x-1))==0)&&(x!=0);
}
(9)不用temp交换两个整数
void swap(int x , int y)
{
x ^= y;
y ^= x;
x ^= y;
}
(10)计算绝对值
int abs( int x )
{
int y ;
y = x >> 31 ;
return (x^y)-y ; //or: (x+y)^y
}
(11)取模运算转化成位运算 (在不产生溢出的情况下)
a % (2^n) 等价于 a & (2^n - 1)
(12)乘法运算转化成位运算 (在不产生溢出的情况下)
a * (2^n) 等价于 a < < n
(13)除法运算转化成位运算 (在不产生溢出的情况下)
a / (2^n) 等价于 a>> n
例: 12/8 == 12>>3
(14) a % 2 等价于 a & 1
(15) if (x == a) x= b;
   else x= a;
   等价于 x= a ^ b ^ x;
(16) x 的 相反数 表示为 (~x+1)


实例

功能 | 示例 | 位运算
----------------------+---------------------------+--------------------
去掉最后一位 | (101101->10110) | x >> 1
在最后加一个0 | (101101->1011010) | x < < 1
在最后加一个1 | (101101->1011011) | x < < 1+1
把最后一位变成1 | (101100->101101) | x | 1
把最后一位变成0 | (101101->101100) | x | 1-1
最后一位取反 | (101101->101100) | x ^ 1
把右数第k位变成1 | (101001->101101,k=3) | x | (1 < < (k-1))
把右数第k位变成0 | (101101->101001,k=3) | x & ~ (1 < < (k-1))
右数第k位取反 | (101001->101101,k=3) | x ^ (1 < < (k-1))
取末三位 | (1101101->101) | x & 7
取末k位 | (1101101->1101,k=5) | x & ((1 < < k)-1)

取右数第k位 | (1101101->1,k=4) | x >> (k-1) & 1

把末k位变成1 | (101001->101111,k=4) | x | (1 < < k-1)
末k位取反 | (101001->100110,k=4) | x ^ (1 < < k-1)
把右边连续的1变成0 | (100101111->100100000) | x & (x+1)
把右起第一个0变成1 | (100101111->100111111) | x | (x+1)
把右边连续的0变成1 | (11011000->11011111) | x | (x-1)
取右边连续的1 | (100101111->1111) | (x ^ (x+1)) >> 1
去掉右起第一个1的左边 | (100101000->1000) | x & (x ^ (x-1))
判断奇数 (x&1)==1
判断偶数 (x&1)==0

分享到:
评论

相关推荐

    位运算常用操作总结

    ### 位运算常用操作总结 位运算是一种对二进制数据进行操作的高效方式,在计算机科学领域具有广泛的...以上是位运算的一些典型应用案例,掌握这些技巧可以帮助我们在编程中更高效地处理二进制数据,提高程序的性能。

    免费下载:C语言难点分析整理.doc

    位运算应用口诀和实例 这部分提供了一些位运算的实用示例和记忆技巧。 ### 35. 内存对齐与ANSI C中struct内存布局 这部分解释了内存对齐的概念以及在C语言中如何影响结构体的内存布局。 ### 36. 冒泡和选择排序...

    C语言难点分析整理

    34. 位运算应用口诀和实例 170 35. 内存对齐与ANSI C中struct内存布局 173 36. 冒泡和选择排序实现 180 37. 函数指针数组与返回数组指针的函数 186 38. 右左法则- 复杂指针解析 189 39. 回车和换行的区别 192 40. 堆...

    高级C语言 学完C语言来看这个绝对收获

    位运算应用口诀和实例 位运算的应用非常广泛,例如用于快速实现位翻转、位移等操作。 #### 32. 内存对齐与ANSIC中struct内存布局 内存对齐是为了提高数据访问速度,而不同的编译器可能会有不同的内存对齐策略。 ...

    的乘法口诀和用口诀求商PPT学习教案.pptx

    这篇PPT学习教案主要针对的是基础数学中的乘法口诀及其在求商中的应用,适合初学者或需要复习巩固的学生。乘法口诀是学习算术运算的...通过反复练习和应用,学生可以巩固基础,为后续更复杂的数学运算打下坚实的基础。

    二年级数学下册 9的乘法口诀和用口诀求商2教案 冀教版 教案.doc

    4. 专项训练:通过具体问题,如金鱼分缸的实例,让学生进一步巩固9的乘法口诀在解决实际问题中的应用。 5. 课堂小结:回顾本节课所学内容,强调9的乘法口诀在日常生活中的实用性,鼓励学生在日常生活中寻找数学的...

    年级数学凑十法口诀,10以内数的连加、连减以及混合运算复习题.doc

    复习题部分包含了各种形式的填空题和应用题,旨在检验学生对凑十法、进位加法、退位减法的理解和运用能力。例如,填空题涉及了数的顺序、加减法运算,以及比较大小的问题。此外,还有图形排列和数的相对位置问题,这...

    乘法口诀和口诀求商(复习二).ppt

    在小学数学的学习中,乘法口诀和口诀求商是基础且重要的概念,它们是进行加法、减法、乘法和除法运算的基础工具。乘法口诀,也称为九九表,是中国传统教育中教授孩子快速记忆乘法结果的一种方式。它通过一句句简短的...

    的乘法口诀人教新课标二年级上册数学PPT课件.pptx

    这篇PPT课件是针对人教版小学二年级上册数学课程中的乘法口诀进行讲解的。乘法口诀是学习基础数学运算的重要部分,它帮助学生...通过丰富的教学形式和贴近生活的实例,帮助小学生建立起对乘法的深刻理解和熟练应用。

    冀教数学二级下册的乘法口诀和用口诀求商PPT学习教案.pptx

    总的来说,这份冀教数学二级下册的乘法口诀和用口诀求商的PPT学习教案,旨在通过寓教于乐的方式,帮助学生熟练掌握乘法口诀,理解并运用口诀解决除法问题,同时培养他们将数学知识应用于实际生活的能力。通过各种...

    和的乘法口诀PPT学习教案.pptx

    例如,二三得六、三四十二等,这些都是基础乘法的练习,通过反复练习和应用,孩子们可以更加熟练地掌握这些口诀。 最后,PPT还包含了一些基于加法和乘法的混合运算问题,比如“亮亮看书”和“串糖葫芦”的例子,...

    乘法口诀的应用PPT学习教案.pptx

    总的来说,这个乘法口诀的应用PPT学习教案通过丰富的实例和多样的解题方法,旨在帮助学生深入理解乘法口诀,提高他们运用数学知识解决实际问题的能力,同时也注重培养他们的创新思维和独立思考的习惯。

    2、3的乘法口诀.ppt

    在【部分内容】中,我们首先回顾了与5相关的乘法,例如3×5=15,5×2=10等,并通过填空的形式让学生复习和应用这些口诀。接着,学习新知识部分,引导学生通过实例(如杯子和灯的数量)来理解和创造3的乘法口诀。之后...

    四年级数学下册1四则混合运算单元概述和课时安排素材西师大版

    4. **探索与问题解决的结合**:设计问题让学生探索不同的运算方法,从而自然地引入和应用混合运算。 根据给出的课时安排,这个单元计划用4课时完成,分别涵盖了解决稍复杂的实际问题、有小括号的混合运算、有两个小...

    人教小学数学二年级上册 的乘法口诀PPT学习教案.pptx

    这份PPT教案包含了丰富的互动环节,以生动有趣的方式引导学生理解和应用乘法。 乘法口诀是学习数学的基础,尤其对于二年级的学生来说,它是计算和解决问题的关键工具。在PPT的第一部分,通过“我们种的向日葵发芽了...

    的乘法口诀 PPT学习教案.pptx

    第四页提出了两个填空题目,如"( ) ×( )",可能需要学生填写合适的数字以完成乘法表达式,这旨在检验他们对乘法口诀的理解和应用。 第五页包含了一些乘法运算的实际练习,如7×3=21,7×5=35等,这些计算练习要求...

    小学生除法口诀表.rar

    3. **除法应用实例**:为了帮助孩子们更好地理解除法的实际应用,口诀表可能还会包含一些生活中的例子,比如分苹果、分配物品等,让抽象的数学概念变得具象化。 4. **练习题**:口诀表中通常会配有相应的练习题,让...

    数学二年级下册用789乘法口诀求商PPT学习教案.pptx

    PPT中的实例还涉及了多个连除问题,如10÷5÷5,通过连续应用乘法口诀,可以迅速得出结果。这种训练能提高学生的计算速度和思维灵活性。 此外,教案通过生动的情境,如“小猪嘟嘟用乘法计算小旗的数量”和“帮小鸟...

    的乘法口诀6PPT学习教案.pptx

    本资料主要关注的是6的乘法口诀,通过生动有趣的例子和实际生活情境,帮助学习者深入理解和应用这些口诀。 乘法口诀是计算的基础工具,它将乘法运算简化为易于记忆的短语,如“三五十五”、“四六二十四”等。在6的...

    的乘法口诀练习课PPT学习教案.pptx

    《乘法口诀练习课》PPT学习教案旨在帮助学生熟练掌握乘法口诀,尤其是一至五的乘法规律,这是...在教学过程中,教师可以结合实例,让孩子们在解决实际问题中体验乘法的魅力,从而更好地理解和掌握这一重要数学概念。

Global site tag (gtag.js) - Google Analytics