首页 > 其他分享 >【总结】浅刷leetcode,对于位运算提高性能的一些总结

【总结】浅刷leetcode,对于位运算提高性能的一些总结

时间:2023-04-21 16:34:42浏览次数:33  
标签:总结 xor 运算 int 异或 按位 static 浅刷 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

标签:总结,xor,运算,int,异或,按位,static,浅刷,leetcode
From: https://www.cnblogs.com/xuyd/p/17340868.html

相关文章

  • ubuntu常用命令总结
    本地与服务器之间copy文件输入命令:【scp/path/to/source/file.tar.gzuser@destination:/path/to/destination/】/path/to/source/file.tar.gz是要复制的源文件的路径和文件名。user是目标服务器的用户名。destination是目标服务器的IP地址或主机名。:/path/to/destin......
  • leetcode_打卡10
    leetcode_打卡10题目:283.移动零思路:双指针,数值互相交换,不是复制覆盖代码:classSolution{publicvoidmoveZeroes(int[]nums){intn=nums.length;intl=0,r=0;while(r<n){if(nums[r]!=0){swap(nums,l,r);......
  • leetcode_打卡09
    leetcode_打卡09题目:443.压缩字符串思路:双指针代码:classSolution{publicintcompress(char[]chars){intn=chars.length;intwrite=0,left=0;for(intread=0;read<n;read++){if(read==n-1||chars[r......
  • hive 知识总结
      hive为何要修改数据库: deby只支持一个SESSION会话,如果hive使用默认的deby,那么在linux客户端开启第二个Hive命令行的时候,会报错,而mysql是支持多会话的数据库。  hive对应的列为何不规定长度:  不确定这些字段的长度,而且最终存储在hdfs文件中(联想与txt)txt中也没法规......
  • 【DP】LeetCode 312. 戳气球
    题目链接312.戳气球思路参考动态规划套路解决戳气球问题分析动态规划题目的时候只需要考虑最后一个阶段,因为所有的阶段转化都是相同的,考虑最后一个阶段容易发现规律在数组的动态规划问题中,一般dp[i]都是表示以nums[i]为结尾的状态;dp[i][j]分别表示以nums1[i]和nums......
  • AutoGPT、AgentGPT、BabyAGI、HuggingGPT、CAMEL:各种基于GPT-4自治系统总结
    ChatGPT和LLM技术的出现使得这些最先进的语言模型席卷了世界,不仅是AI的开发人员,爱好者和一些组织也在研究探索集成和构建这些模型的创新方法。各种平台如雨后春笋般涌现,集成并促进新应用程序的开发。AutoGPT的火爆让我们看到越来越多的自主任务和代理利用了GPT-4的API。这些发展......
  • Android进程间通信总结
    原文地址blog.csdn.netIPCIPC为(Inter-ProcessCommunication)缩写,称为进程间通信或跨进程通信,指两个进程间进行数据交换的过程。安卓中主要采用Binder进行进程间通信,当然也支持其他IPC方式,如:管道,Socket,文件共享,信号量等。Binder简介1.为什么使用Binder?性能方面:......
  • leetcode-876链表的中间节点
    找链表的中间节点思路心得当不知道while的终止条件时,可以先写while(true),然后在循环体中写终止条件,这样写的好处是可以暂时不考虑终止条件,使思路更清晰;坏处是这样有时候会使循环体的内容很混乱要注意分类!本题中把情况分为节点个数是奇数和偶数去分析,最终找到统一的......
  • leetcode-234回文链表
    回文链表方法一:借助数组进行判断把节点的值复制到一个数组中再利用数组进行判断,但是这样需要占用额外的空间/***Definitionforsingly-linkedlist.*structListNode{*intval;*ListNode*next;*ListNode():val(0),next(nullptr){}*......
  • 2023.4.20每日总结
    今天完成了什么:今天完成了对于数据插入时进行确认时碰到的问题,现在已经可以成功的让用户确认及修改数据以及删除数据了遇到了哪些困难:在完成昨天碰到的问题之后,紧接着就转向了根据消费类型以及消费金额来生成相应的总账单图,不知如何下手,明天打算完成这部分明天打算做什么:完成根......