位运算符的介绍和使用

我们先来介绍位运算符的一些知识:

1.位运算符

(1).& 有0就是0

(2).有1就是1

(3).^相同为0,不同为1

2.判断第x为是0还是1

先将1<<x,在n&1,如果结果为0则是0,否则是1.

3.将第n位修改为1

1<<x,然后1|x;

4.将第x位修改为0

1<<x,然后1&x

5.位图的思想

就是利用哈希表来解决一些问题。

6.提取最右侧的1

n&(-n)

7.去掉最右侧的1

n&(n-1)

8.优先级

能加括号就加括号

9^运算率

a^0=a;

a^a=0;

(a^b)^c=a^(b^c);

我们来看几道例题:

class Solutionpublic:bool isUnique(string astr)

// 利用鸽巢原理来做的优化if(astr.size() > 26) return false;

1213

int bitMap = 0;for(auto ch : astr)

inti=ch-'a';//先判断字符是否已经出现过if(((bitMap >> i) & 1) == 1) return false;

return true;

};

利用位运算实现两个整数的和

#include<iostream>

#include<string>

using namespace std;

int main()

{

int a, b;

cin >> a >> b;

while (b != 0) {

int x;

x = a ^ b;

b = (a & b) << 1;

a = x;

}

cout << a << endl;

return 0;

}

class Solution {

public:

int missingNumber(vector<int>& nums) {

int ret=0;

for(auto e: nums){

ret=ret^e;

}

int n=nums.size();

for(int i=0;i<=n;i++){

ret^=i;

}

return ret;

}

};

相关推荐
智者知已应修善业3 小时前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
apcipot_rain3 小时前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络
scx_link3 小时前
逻辑回归的总结
算法·机器学习·逻辑回归
沐籽李3 小时前
Proteina-Complexa:NVIDIA 如何把蛋白 Binder 设计推进到全原子生成时代?
大数据·人工智能·算法·英伟达·蛋白质生成
落羽的落羽3 小时前
【项目】JsonRpc框架——开发实现2(业务层)
linux·数据结构·c++·人工智能·算法·json·动态规划
h_a_o777oah3 小时前
2026 蓝桥杯软件 C++B组 国赛比赛经历及备赛建议
c++·经验分享·算法·蓝桥杯
SHARK_pssm3 小时前
【数据结构——单链表】
数据结构·经验分享·笔记
lightqjx4 小时前
【算法】数据结构_并查集
数据结构·算法·并查集
小雨下雨的雨4 小时前
鸿蒙PC Electron框架实现流体气泡模拟器
前端·人工智能·算法·华为·electron·鸿蒙
txzrxz4 小时前
广度优先搜索详解(BFS)
算法·宽度优先