位运算符的介绍和使用

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

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;

}

};

相关推荐
灵感__idea4 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
lwf0061646 小时前
导数学习日记
学习·算法·机器学习
头发够用的程序员7 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此7 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn8 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越8 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光8 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
CappuccinoRose9 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦9 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav10 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi