【总结】浅刷leetcode,对于位运算提高性能的一些总结
目录
什么是位运算?
位运算技巧
1. 判断奇偶性
2. 交换两个数
3. 判断一个数是否是2的幂次方
4. 取绝对值
5. 计算平均数
结论
位运算技巧是计算机科学中非常重要的一部分,它可以用来解决很多实际问题。在本篇博客中,我们将介绍一些常见的位运算技巧,以及它们在实际应用中的使用。
什么是位运算?
        位运算是一种对二进制数进行操作的运算。它包括按位与、按位或、按位异或、按位取反等操作。在计算机中,位运算是非常快速的,因为它们可以直接在硬件层面上执行。
位运算技巧
1. 判断奇偶性
        我们可以使用位运算来判断一个数的奇偶性。如果一个数的二进制表示的最后一位是0,那么它就是偶数,否则它就是奇数。因此,我们可以使用按位与运算符(&)来判断一个数的奇偶性。
public static bool IsEven(int n)
        {
            return n % 2 == 1;
        }
        public static bool IsEven(int n)
        {
            return (n & 1) == 0;
        }
        相比于n%2通过取模运算来判断一个数字是否是奇偶数,&运算性能快非常多。取模运算的实现原理是,将被除数按位分解得到的每一位与除数相比较,如果大于除数,则将除数不断左移一位(乘2),直到它大于被除数为止,然后将被除数减去这个数,再进行下一次比较。如果小于除数,则将对应的商位为0,然后考虑下一位。
2. 交换两个数
        我们可以使用位运算来交换两个数的值。假设我们有两个变量a和b,我们可以使用异或运算符(^)来交换它们的值。
交换两个数有很多种实现方法
比如通过临时变量,通过加减法
static bool Swap(ref int a,ref int b)
        {
            //通过临时变量
            int temp = a; 
            a = b; 
            b = temp;
 
            //通过加法或者减法省去临时变量
            a += b;
            b -= a;
            a -= b;
        }
        利用异或的性质交换两个数,是性能最好的一种手段。
static bool Swap(ref int a, ref int b)
        {
            //通过异或交换两个数的值
            a ^= b;
            b ^= a;
            a ^= b;
        }
异或基本性质如下:
1. 可逆性:A xor B等于C,那么C xor B等于A,C xor A等于B。也就是说,对于任意两个值进行异或运算所得的结果,只要其中有一个值和结果以及另外一个值已知,就可以得到另外一个值。
2. 结合律和交换律:异或运算可以任意交换和结合,例如(A xor B) xor C = A xor (B xor C),A xor B = B xor A。
3. 自反性:一个数和自己异或的结果为0,即A xor A = 0。
4. 零值:任何数和0进行异或的结果都等于这个数本身,即A xor 0 = A。
异或运算在计算机中有广泛应用,例如数据加密、压缩、校验等领域。其中,数据校验往往采用奇偶校验或者循环冗余校验(CRC)算法,而这些算法都需要用到异或运算。此外,在编程语言中,异或运算也经常用于实现位操作和状态判断等功能。
3. 判断一个数是否是2的幂次方
        如果一个数是2的幂次方,那么它的二进制表示中只有一位是1,其余位都是0。因此,我们可以使用按位与运算符(&)来判断一个数是否是2的幂次方。n & (n - 1)的运算结果可以将n的二进制表示中的最后一个1变成0,其他位保持不变,也就是把n的最低位的1变成0。另外,n & (n - 1)的运算还可以用于统计一个二进制数中1bits的个数。如果一个数的二进制表示中有k个1bit,那么对这个数连续做k次n & (n - 1)操作,就可以将二进制表示中的所有1bit都消除。
static bool IsPowerOfTwo(int n) 
        { 
            return (n & (n - 1)) == 0;
        }
4. 取绝对值
        我们可以使用位运算来取一个数的绝对值。假设我们有一个变量n,我们可以使用按位与运算符(&)和减法运算符(-)来取它的绝对值。
public static int Abs(int n) 
        {
            int mask = n >> 31; return (n + mask) ^ mask;
        }
5. 计算平均数
        我们可以使用位运算来计算两个数的平均数。假设我们有两个变量a和b,我们可以使用位运算符(>>)来计算它们的平均数。
public static int Average(int a, int b) 
        { 
            return (a & b) + ((a ^ b) >> 1); 
        }
结论
        位运算技巧在计算机科学中是非常重要的。它们可以用来解决很多实际问题,例如判断奇偶性、交换两个数、判断一个数是否是2的幂次方、取绝对值和计算平均数等。在实际应用中,我们应该根据具体情况选择合适的位运算技巧来解决问题。
————————————————
版权声明:本文为CSDN博主「徐欲东」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/XuYuDong_/article/details/130262839
【总结】浅刷leetcode,对于位运算提高性能的一些总结的更多相关文章
- LeetCode:位运算实现加法
		
LeetCode:位运算实现加法 写在前面 位运算符 实现加法的思路 两个加数,比如5(101)和6(110),如何不用加法就能得出两者之和呢? 我们知道二进制计算中,如果使用异或将会产生无进位的两者 ...
 - 【LeetCode】位运算 bit manipulation(共32题)
		
[78]Subsets 给了一个 distinct 的数组,返回它所有的子集. Example: Input: nums = [,,] Output: [ [], [], [], [,,], [,], ...
 - Apriori算法-位运算-C语言
		
原文地址:http://blog.csdn.net/liema2000/article/details/6118423 //////////////////////////////////////// ...
 - Python这些位运算的妙用,绝对让你大开眼界
		
位运算的性能大家想必是清楚的,效率绝对高.相信爱好源码的同学,在学习阅读源码的过程中会发现不少源码使用了位运算.但是为啥在实际编程过程中应用少呢?想必最大的原因,是较为难懂.不过,在面试的过程中,在手 ...
 - LeetCode刷题总结-双指针、位运算和分治法篇
		
本文总结LeetCode上有关双指针.位运算和分治法的算法题,推荐刷题总数14道.具体考点分析如下图: 一.双指针 1.字符串和数组问题 题号:424. 替换后的最长重复字符,难度中等 题号:828. ...
 - C#LeetCode刷题-位运算
		
位运算篇 # 题名 刷题 通过率 难度 78 子集 67.2% 中等 136 只出现一次的数字 C#LeetCode刷题之#136-只出现一次的数字(Single Number) 53.5% 简单 ...
 - leetcode - 位运算题目汇总(下)
		
接上文leetcode - 位运算题目汇总(上),继续来切leetcode中Bit Manipulation下的题目. Bitwise AND of Numbers Range 给出一个范围,[m, ...
 - leetcode - 位运算题目汇总(上)
		
最近在看位运算的知识,十分感叹于位运算的博大精深,正好leetcode有 Bit Manipulation 的专题,正好拿来练练手. Subsets 给出一个由不同的数字组成的数组,枚举它的子数组(子 ...
 - LeetCode解题中位运算的运用
		
位运算是我最近才开始重视的东西,因为在LeetCode上面刷题的时候发现很多题目使用位运算会快很多.位运算的使用包含着许多技巧(详细可以参考http://blog.csdn.net/zmazon/ar ...
 - LeetCode编程训练 - 位运算(Bit Manipulation)
		
位运算基础 说到与(&).或(|).非(~).异或(^).位移等位运算,就得说到位运算的各种奇淫巧技,下面分运算符说明. 1. 与(&) 计算式 a&b,a.b各位中同为 1 ...
 
随机推荐
- ant build 报 warning modified in the future
			
错误原因:在测试项目时,修改了系统时间,之后保存了文件,再将系统时间改回来,会报这个错误 解决方法:复制改过的文件到记事本,然后回退下文件,再将记事本的内容覆盖下文件,重新build下就可以了.
 - C++ 全面总结
			
1. 基本数据类型:没什么好说的.知道浮点数存储起来不精确.各种类型占的大小在不同平台可能不一样就行了 2. 初始化列表:能用就用.能防止潜在的类型收窄, 3. static_cast 和 dynam ...
 - Day06 ServletContext
			
ServletContext的介绍与用法 1.什么是ServletContext 1.1 SevrvletContext:Servlet上下文 服务器会为每一个Web工程创建一个ServletCont ...
 - ffmpeg均匀分割视频命令
			
ffmpeg -y -i input.wav -f segment -segment_time 5 output-%d.wav -segment_time 分割视频片段大小 -segmenet_lis ...
 - Sqoop从MySQL向Hive增量式导入数据报错:Exception in thread "main" java.lang.NoClassDefFoundError: org/json/JSONObject
			
1.问题描述: (1)问题示例: Step1:创建作业: [Hadoop@master TestDir]$ sqoop job \> --create myjob_1 \> -- impo ...
 - NX二次开发 拔模增量计算工具
			
在塑胶模具设计行业拔模增量计算经常都需要用到,平常都是利用计算器工具或者外部的计算工具去算.曾经有一个模具设计的培训老师把拔模增量计算工具称为模具设计的神器,好吧,我也造个神器.-_-! VS2019 ...
 - Tensorflow learning notebook
			
How does tensorflow work 原著blog https://jacobbuckman.com/#posts
 - FCARM - Output Name not specified, please check 'Options for Target - Utilit问题
			
FCARM - Output Name not specified, please check 'Options for Target - Utilit问题 按照书上说明按步操作,但是书上是按照kei ...
 - (Winform程序带源码) 弹出输入框和获取输入框的值
			
弹出输入框和获取输入框的值: private void button1_Click(object sender, EventArgs e) { string returnValue = Microso ...
 - 01.html大致主体格式
			
<!DOCTYPE html> 不是HTML标签,就是文档声明标签 告诉浏览器使用哪种html版本来显示网页,其必须在文档中的最前面位置,要放在<html>标签之前, < ...