算法修炼之路之位运算

目录

一:位运算符及一些常用结论总结

1.给一个数n,确定它的二进制表示中的第x位是0还是1(位数从右向左0开始增加)

2.将一个数n的二进制表示形式的第x位修改成1

3.将一个数n的二进制表示的第x位修改为0

4.提取一个数n的二进制表示中最右侧的1

5.干掉一个数n的二进制表示中最右侧的1

[二:LeetCode OJ练习](#二:LeetCode OJ练习)

1.第一题

2.第二题

3.第三题

4.第四题

5.第五题

一:位运算符及一些常用结论总结

知识传送门 位运算符介绍

1.给一个数n,确定它的二进制表示中的第x位是0还是1(位数从右向左0开始增加)

2.将一个数n的二进制表示形式的第x位修改成1

3.将一个数n的二进制表示的第x位修改为0

4.提取一个数n的二进制表示中最右侧的1

5.干掉一个数n的二进制表示中最右侧的1

二:LeetCode OJ练习

1.第一题

OJ传送门 LeetCode 面试题01.01 判断字符是否唯一

画图分析:

具体代码:

cpp 复制代码
bool isUnique(string str) 
    {
        int len=str.size();
        if(len>26) return false;//利用鸽巢原理做优化
        int bitMap=0;

        for(auto ch :str)
        {
            int x=ch-'a';
            //先判断字符是否已经存在
            if((bitMap>>x)&1==1) return false;
            //把当前字符加入到位图中
            bitMap=bitMap | (1<<x);
        }

        return true;
    }

2.第二题

OJ 传送门 LeetCode_268 消失的数字

画图分析;

具体代码:

cpp 复制代码
int missingNumber(vector<int>& nums) 
    {
        int n=nums.size();
        int ret=0;

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

        for(auto x:nums)
        {
            ret^=x;
        }

        return ret;
    }

3.第三题

OJ 传送门 LeetCode_371 两整数之和

画图分析:

具体代码:

cpp 复制代码
int getSum(int a, int b) 
    {
        while(b)
        {
            int x=a^b;//先算出无进位相加的结果
            unsigned int carry=(unsigned int)((a&b)<<1);//算出进位
            a=x;
            b=carry;
        }

        return a;
    }

4.第四题

OJ传送门 LeetCode_137 只出现一次的数字 II

画图分析:

具体代码:

cpp 复制代码
int singleNumber(vector<int>& nums) 
    {
        int ret=0;

        for(int i=0;i<32;++i)//依次修改ret的每一位
        {
            int sum=0;//统计每个bit位的数组和
            for(auto x:nums)
            {
                if(((x>>i)&1)==1) sum++;
            }

            if(sum%3==1) ret|=(1<<i);//放入到对应bit位中
        }

        return ret;
    }

5.第五题

OJ 传送门 LeetCode 面试题 17.19 消失的两个数字

画图分析:

具体代码:

cpp 复制代码
 vector<int> missingTwo(vector<int>& nums) {
        //1.将所有数据异或在一起
        int tmp=0,n=nums.size();
        for(auto x:nums) tmp^=x;
        for(int i=1;i<=n+2;++i) tmp^=i;

        //2.寻找bit为1的位置
        int pos=0;
        while(1)
        {
            if(((tmp>>pos)&1)==1) break;
            else ++pos;
        }

        //3.根据此位置将数据分为两组
        int a=0,b=0;
        for(auto x:nums)
        {
            if(((x>>pos)&1)==1) a^=x;
            else b^=x;
        }
        for(int i=1;i<=n+2;++i)
        {
            if(((i>>pos)&1)==1) a^=i;
            else b^=i;
        }

        return {a,b};
    }
相关推荐
北域码匠23 分钟前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
成都易yisdong32 分钟前
上海某平面坐标系与CGCS2000坐标互转详解(含全域拟合点、实战案例、保密规范)
大数据·人工智能·算法
2601_9618451544 分钟前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
快手技术1 小时前
征集令|快手探索者LLM-Rec挑战赛正式发布!
算法
Yvonne爱编码1 小时前
JAVA EE初阶---DAY 2 计算机网络
java·开发语言·计算机网络·算法·java-ee·php
workflower1 小时前
基于机器学习的设备故障预测分析方法
人工智能·算法·机器学习·设计模式·语言模型·自然语言处理·重构
格发许可优化管理系统1 小时前
Mentor许可证与其他软件许可证的深度比较
java·大数据·运维·c语言·c++·算法
wjcroom2 小时前
时空和电子7-泡力模型含罗量
人工智能·算法·机器学习
KaMeidebaby2 小时前
卡梅德生物技术快报 | Fab 合成文库构建与抗体筛选实验流程及数据解析
人工智能·python·tcp/ip·算法·机器学习
金融小师妹2 小时前
基于AI事件驱动模型与验证溢价框架的市场分析:从预期交易到事实验证,原油与黄金面临关键定价重构
大数据·人工智能·算法·均值算法·线性回归