【刷题】位运算

消失的两个数字 

消失的两个数字

“单身狗”进阶版思路

class Solution {
public:
    vector<int> missingTwo(vector<int>& nums) {
        int ret = 0;
        int n = nums.size();
        for(int i = 0; i < n; i++)
        {
            ret ^= (nums[i] ^ i);
        }
        ret ^= (n ^ (n + 1) ^ (n + 2));
        // 按位异或的规则是相异为1
        // 找出从最低位开始第一次出现 1 的位置,这个位置一定对应两个数字的二进制位是一个为0 ,一个为1
        int flag = 0;
        while(!((ret >> flag) & 1)) flag++;
        vector<int> v1;
        vector<int> v2;
        for(int i = 0; i < n; i++)
        {
            if(((nums[i] >> flag) & 1) == 1) v1.push_back(nums[i]);
            else v2.push_back(nums[i]);
        }
        for(int i = 1; i < n + 3; i++)
        {
             if(((i >> flag) & 1) == 1) v1.push_back(i);
             else v2.push_back(i);
        }
        // 对 v1 和 v2 分别操作
        vector<int> v3;
        int tar = 0;
        for(int i = 0; i < v1.size(); i++)
        {
            tar ^= v1[i];
        }
        v3.push_back(tar);
        tar = 0;
        for(int i = 0; i < v2.size(); i++)
        {
            tar ^= v2[i];
        }
        v3.push_back(tar);
        return v3;
    }
};

只出现一次的数字 II

只出现一次的数字 II

思路:将所有数字的每一位比特位相加,这些比特位的和有如下规律:

只需要定义一个整形变量,通过上述方法计算出它的每一个比特位即可! 

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int ret = 0; // 只出现一次的数字
        for(int i = 0; i < 32; i++)
        {
            // 修改第 i 位的值
            // 将每个数的第 i 个比特位加起来
            int sum = 0;
            for(int j = 0; j < nums.size(); j++)
            {
                sum += ((nums[j] >> i) & 1);
            }
            sum %= 3;
            ret |= (sum << i);
        } 
        return ret;
    }
};

两整数之和 

两整数之和

class Solution {
public:
    int getSum(int a, int b) {
        // ^ 是无进位相加,只需要每次找到进的位,再相加,等到进位为 0 的时候,就结束了
        int sum = a ^ b;
        size_t carry = (size_t)((a & b) << 1); // carry 是进的位
        while(carry)
        {
            a = sum, b = carry;
            sum = a ^ b;
            carry = size_t((a & b) << 1);
        }
        return sum;
    }
};

^ 异或运算是:两个数对应比特位相同为0,相异为1,也叫 不进位相加

只需要利用按位异或运算符进行不进位相加运算,然后每次加上它的进位即可!直到进位为0!

判断字符是否唯一

判定字符是否唯一

两种方法:哈希表和位图(位图是进阶方法)

哈希表

class Solution {
public:
    bool isUnique(string astr) {
        int a[26] = { 0 };
        for(int i = 0; i < astr.size(); i++)
        {
            a[astr[i] - 'a'] ++ ;
        }
        for(int i = 0; i < 26; i++)
        {
            if(a[i] > 1) return false;
        }
        return true;
    }
};

位图

和哈希表思路一样,但是将标记存在32个比特位中,利用位运算来控制比特位的值!

class Solution {
public:
    bool isUnique(string astr) {
        int n = astr.size();
        if(n > 26) return false;
        int bit_set = 0; // 一个位图整形
        for(int i = 0; i < n; i++)
        {
            int a = bit_set >> (astr[i] - 'a'); // bit_set 移位后的数
            if((a & 1) == 0) 
            {
                bit_set |= (1 << (astr[i] - 'a'));
            }
            else if((a & 1) == 1) return false;
        }
        return true;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/420580.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于SpringBoot的综合小区管理系统的设计与实现

文章目录 项目介绍主要功能截图&#xff1a;部分代码展示设计总结项目获取方式 &#x1f345; 作者主页&#xff1a;超级无敌暴龙战士塔塔开 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &…

Linux 安装k8s

官网 常见的三种安装k8s方式 1.kubeadm 2.kops&#xff1a;自动化集群制备工具 3.kubespray&#xff1a; 提供了 Ansible Playbook 下面以kubeadm安装k8s kubeadm的安装是通过使用动态链接的二进制文件完成的&#xff0c;目标系统需要提供 glibc ##使用 ss 或者 netstat 检测端…

.halo勒索病毒的最新威胁:如何恢复您的数据?

尊敬的读者&#xff1a; 随着科技的发展&#xff0c;网络安全已经成为我们日常生活中不可忽视的重要议题。其中&#xff0c;勒索病毒是当前网络安全威胁中的一大挑战&#xff0c;而“.halo”勒索病毒更是近期备受关注的恶意软件之一。本文将介绍关于“.halo”勒索病毒的背景知…

循环简介和基本运算符

根据C Primer Plus第五章进行学习 文章目录 循环简介基本运算符 1.赋值运算符&#xff1a;2.加法运算符&#xff1a;3.减法运算符&#xff1a;-2.乘法运算符&#xff1a;*总结 1.循环简介 如下代码可以体现不使用循环的局限性&#xff1a; #include<stdio.h> #define AD…

【C语言】linux内核xmit_one函数

一、中文注释 static int xmit_one(struct sk_buff *skb, struct net_device *dev,struct netdev_queue *txq, bool more) {unsigned int len;int rc;// 如果全局ptype列表或者设备特定的ptype列表不为空&#xff0c;则执行网络接口层网络层的NIT&#xff08;Network Tap&…

【C++】vector的使用及其模拟实现

这里写目录标题 一、vector的介绍及使用1. vector的介绍2. 构造函数3. 遍历方式4. 容量操作及空间增长问题5. 增删查改6. vector二维数组 二、vector的模拟实现1. 构造函数2. 迭代器和基本接口3. reserve和resize4. push_back和pop_back5. insert和erase5. 迭代器失效问题5. 浅…

docker 基础(二)

常见命令 Docker最常见的命令就是操作镜像、容器的命令&#xff0c;详见官方文档&#xff1a;https://docs.docker.com/ 数据卷 命令说明文档地址docker volume create创建数据卷docker volume createdocker volume ls创建数据卷docker volume lsdocker volume rm查看所有数…

NGINX 高频面试题及实践总结

NGINX 是一个高性能的开源 Web 服务器和反向代理服务器&#xff0c;被广泛应用于互联网架构中。在面试中&#xff0c;对 NGINX 的相关知识可能会成为考察的重点。下面我们整理了一些常见的 NGINX 面试题及答案&#xff0c;希望对大家在面试前的准备有所帮助。 ## 1. 什么是 NG…

如何系统性的学习推荐系统?

推荐一本适合推荐系统、计算广告、个性化搜索领域的从业人员阅读的书&#xff1a;《互联网大厂推荐算法实战》。快手公司算法专家10余年的实战经验总结。涵盖一线互联网公司当前采用的主流推荐算法&#xff0c;凸显可用性、实用性提供从算法基本原理&#xff0c;到技术框架再到…

python语言1

一、pytho中的注释 1.1注释的理解 程序员在代码中对代码功能解释说明的标注性文字可以提高代码的可读性注释的内容将被python解释器忽略&#xff0c;不被计算机执行 1.2注释的分类 注释分为&#xff1a;单行注释、多行注释、中文声明注释 &#xff08;1&#xff09;单行注…

java项目打包运行报异常:xxxxx-1.0-SNAPSHOT.jar中没有主清单属性

pom.xml中加入这段话即可 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>2.4.4</version><executions><execution><…

雨云:为你拨开云雾见青天

一、雨云品牌概览 雨云&#xff0c;这名字一听就让人联想到蓝天白云&#xff0c;清爽自然。那么&#xff0c;这个品牌是否真的如其名&#xff0c;能为我们这些在数字世界中漂泊的旅人提供一片宁静、稳定的“云”呢&#xff1f;接下来&#xff0c;让我们深入了解雨云的资质、能…

【Micropython教程】I2C的使用

文章目录 前言一、I2C的使用1.1 分析一种情况1.2 初始化I2C总线1.3 扫描可用的I2C设备1.4 向指定地址写入数据1.5 读取指定地址的数据1.6 关闭I2C总线 二、示例代码总结 前言 MicroPython 是一种精简的 Python 实现&#xff0c;旨在运行在微控制器和嵌入式系统上。在嵌入式开发…

AVL 树

AVL树的概念 二叉搜索树虽可以缩短查找的效率&#xff0c;但如果数据有序或接近有序二叉搜索树将退化为单支树&#xff0c;查找元素相当于在顺序表中搜索元素&#xff0c;效率低下。因此&#xff0c;两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年 发明了一种解决…

vue3的router

需求 路由组件一般放在&#xff0c;pages或views文件夹, 一般组件通常放在component文件夹 路由的2中写法 子路由 其实就是在News组件里面&#xff0c;再定义一个router-view组件 他的子组件&#xff0c;机会渲染在router-view区域 路由传参 <RouterLink :to"/news…

腾讯云最新活动_腾讯云促销优惠_代金券-腾讯云官网入口

腾讯云服务器多少钱一年&#xff1f;62元一年起&#xff0c;2核2G3M配置&#xff0c;腾讯云2核4G5M轻量应用服务器218元一年、756元3年&#xff0c;4核16G12M服务器32元1个月、312元一年&#xff0c;8核32G22M服务器115元1个月、345元3个月&#xff0c;腾讯云服务器网txyfwq.co…

xsslabs第七关

源码 <!DOCTYPE html><!--STATUS OK--><html> <head> <meta http-equiv"content-type" content"text/html;charsetutf-8"> <script> window.alert function() { confirm("完成的不错&#xff01;"…

《2023年勒索软件攻击态势报告》

获取方式&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1zd-yVsuGwJADyyGNFR_TIQ?pwd2lo0 提取码&#xff1a;2lo0

游戏空间划分技术

一、 前言 空间划分算法有很多&#xff0c;比如均匀网格&#xff0c;四/八叉树&#xff0c;k-d树&#xff0c;Bsp树&#xff0c;每一种算法都有自己的优缺点&#xff0c;我们需要从理论上理解这些算法&#xff0c;然后在实际项目中进行灵活的运用。 游戏中经常使用空间划分算…

k8s二进制部署的搭建

1.1 常见k8s安装部署方式 ●Minikube Minikube是一个工具&#xff0c;可以在本地快速运行一个单节点微型K8S&#xff0c;仅用于学习、预览K8S的一些特性使用。 部署地址&#xff1a;Install Tools | Kubernetes ●Kubeadm Kubeadm也是一个工具&#xff0c;提供kubeadm init…
最新文章