当前位置: 首页 > news >正文

网站建设中 动态图片/东莞市网络营销公司

网站建设中 动态图片,东莞市网络营销公司,杭州集团网站建设,苏州做网站外包的公司有哪些目录 1 什么是位运算?2 67. 二进制求和3 136. 只出现一次的数字4 137. 只出现一次的数字 II5 201. 数字范围按位与 1 什么是位运算? ✒️ 源自:位运算 - 菜鸟教程 在现代计算机中,所有数据都以二进制形式存储,…

目录

    • 1 什么是位运算?
    • 2 67. 二进制求和
    • 3 136. 只出现一次的数字
    • 4 137. 只出现一次的数字 II
    • 5 201. 数字范围按位与




1 什么是位运算?

✒️ 源自:位运算 - 菜鸟教程

在现代计算机中,所有数据都以二进制形式存储,即 0 0 0 1 1 1 两种状态。计算机对二进制数据进行的运算(如:加、减、乘、除)被称为位运算,即对二进制数的每一位进行操作的运算。

为了更好地理解位运算,举个简单的例子:假设我们有如下代码进行两个整数的加法运算:

int a = 35;
int b = 47;
int c = a + b;

计算机会将这两个整数转换为二进制形式,然后进行加法运算:

35:  0010 0011
47:  0010 1111
--------------
82:  0101 0010

因此,与直接使用 + + + − - ∗ * / / / 运算符相比,合理运用位运算可以显著提高代码在机器上的执行效率。

✒️ 位运算概览

符号描述运算规则
&两个位都为 1 时,结果才为 1
|两个位都为 0 时,结果才为 0
^异或两个位相同为 0,相异为 1
~取反0 变 1,1 变 0
<<左移各二进制位全部左移若干位,高位丢弃,低位补 0
>>右移各二进制位全部右移若干位,高位补 0 或符号位补齐


2 67. 二进制求和

假设需要计算 a a = 111 aa=111 aa=111 b b = 101 bb=101 bb=101 的和,那么可以将每一位的计算结果分为本位和进位:

在这里插入图片描述

让我们从右往左看整个计算过程:

  • ① 首先是 1 + 1 1+1 1+1,本位是 0 0 0,进位是 1 1 1
  • ② 然后是 1 + 0 1+0 1+0,本位是 1 1 1,进位是 0 0 0
  • ③ 最后是 1 + 1 1+1 1+1,本位是 0 0 0,进位是 1 1 1

通常会在 ② 中加上 ① 产生的进位,即在处理当前位的时候考虑上一位的进位。与之相反,我们不单独考虑进位,而是对进位进行统一处理,即先计算出所有的本位以及所有的进位,再对二者进行求和。

继续来看上面的计算过程,我们已经得到:

  • 本位 = 0...0010 =0...0010 =0...0010
  • 进位 = 0...1010 =0...1010 =0...1010

然后再计算本位和进位的和,得到新的本位和进位。重复上述操作,直到进位为 0 0 0,即没有进位时为止。

核心代码

auto ans = aa ^ bb;  // 按位异或计算本位
auto carry = (aa & bb) << 1;  // 按位与计算进位

其中变量 a n s \mathrm{ans} ans 用于存储所有本位,变量 c a r r y \mathrm{carry} carry 用于存储所有进位。

由于进位是指进到更高的一位,因此需要对按位与的结果进行左移一位的操作。

完整代码

string addBinary(string a, string b) {// 转换为二进制串auto aa = bitset<10001>(a);auto bb = bitset<10001>(b);// 求和while (bb != 0) {auto ans = aa ^ bb;auto carry = (aa & bb) << 1;aa = ans;bb = carry;}// 去除多余的前缀零string ans = aa.to_string();int pos = ans.find('1');if (pos > ans.size()) ans = "0";else ans = ans.substr(pos);return ans;
}


3 136. 只出现一次的数字

题目信息:除了某个元素只出现一次以外,其余每个元素均出现两次,找出那个只出现了一次的元素。

假设元素分别为 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1,a2,...,an,根据异或操作的定义可知:

a i ⊗ a i = 0 a_i \otimes a_i = 0 aiai=0

如果是 a 7 a_7 a7 元素只出现了一次,那么有:

a 1 ⊗ a 2 ⊗ . . . ⊗ a 7 ⊗ . . . ⊗ a n = 0 ⊗ a 7 ⊗ 0 = a 7 a_1 \otimes a_2 \otimes ... \otimes a_7 \otimes ... \otimes a_n = 0 \otimes a_7 \otimes 0 = a_7 a1a2...a7...an=0a70=a7

因此,我们只要对所有元素进行异或,就能找出那个只出现了一次的元素。

完整代码

int singleNumber(vector<int>& nums) {int ans = 0;for (auto & num : nums)ans ^= num;return ans;
}


4 137. 只出现一次的数字 II

本题一看就是上一题的姊妹题,但是完全不能用上一题的思路做。

本题思路:对于数组中非答案的元素,每一个元素都出现了 3 3 3 次,对应着第 i i i 个二进制位的 3 3 3 0 0 0 3 3 3 1 1 1。无论是哪一种情况, 0 0 0 1 1 1 的个数都是 3 3 3 的倍数。现在计算所有元素的第 i i i 个二进制位为 1 1 1 的个数,如果不为 3 3 3 的倍数,那么多余的 1 1 1 一定是答案的第 i i i 个二进制位提供的,即答案的第 i i i 个二进制位为 1 1 1;否则为 0 0 0

说明:“答案” 是指那个只出现了一次的元素。

完整代码

int singleNumber(vector<int>& nums) {int ans = 0;for (int i = 0; i < 32; ++i) {int cnt = 0;for (auto & num : nums) {if (num >> i & 1)++cnt;}if (cnt % 3 == 1)ans |= 1 << i;}return ans;
}

这种解法属于是通用解法了,完全可以用来解决上一题。不过思路这么繁琐,我用哈希表不香吗 😇



5 201. 数字范围按位与

假设 l e f t \mathrm{left} left r i g h t \mathrm{right} right 的前 i i i 位相同,由于 l e f t < r i g h t \mathrm{left<right} left<right 且第 i + 1 i+1 i+1 位不同,因此 l e f t \mathrm{left} left 的第 i + 1 i+1 i+1 位必为 0 0 0 r i g h t \mathrm{right} right 的第 i + 1 i+1 i+1 位必为 1 1 1(从左往右数)。由于前 i i i 位相同,因此按位与的结果等于前 i i i 位本身。如下图所示:

在这里插入图片描述

对于第 i + 1 i+1 i+1 位及剩余的位,因为从 0... . . . . 0...\ .... 0... .... 1... . . . . 1...\ .... 1... .... 必然会经过 1000 0000 1000\ 0000 1000 0000,因此按位与的结果一定为 0000 0000 0000\ 0000 0000 0000。通过上述分析可知,我们只需要找出前 i i i 位相同的部分,剩余的位置为 0 0 0 即可。

完整代码

int rangeBitwiseAnd(int left, int right) {int ans = 0;int pos = 1 << 30;while (pos > 0 && ((left & pos) == (right & pos))) {ans |= (left & pos);pos >>= 1;}return ans;
}

其中变量 p o s \mathrm{pos} pos 从高位到低位,逐位比较 l e f t \mathrm{left} left r i g h t \mathrm{right} right 是否相同。



相关文章:

LeetCode 面试经典 150 题 | 位运算

目录 1 什么是位运算&#xff1f;2 67. 二进制求和3 136. 只出现一次的数字4 137. 只出现一次的数字 II5 201. 数字范围按位与 1 什么是位运算&#xff1f; ✒️ 源自&#xff1a;位运算 - 菜鸟教程 在现代计算机中&#xff0c;所有数据都以二进制形式存储&#xff0c;…...

postMessage 收到消息类型 “webpackWarnings“

场景描述&#xff1a; 当A系统中的parent页面使用iframe内嵌C系统的child页面&#xff0c;并且在parent页面中通过postMessageg给child页面发送消息时&#xff0c;如果C系统中使用了webpack,则webpack也会给child页面发送消息 &#xff0c;消息类型为webpackWarnings。那么如何…...

计算机基础(day1)

1.什么是内存泄漏&#xff1f;什么是内存溢出&#xff1f;二者有什么区别&#xff1f; 2.了解的操作系统有哪些&#xff1f; Windows&#xff0c;Unix&#xff0c;Linux&#xff0c;Mac 3. 什么是局域网&#xff0c;广域网&#xff1f; 4.10M 兆宽带是什么意思&#xff1f;理论…...

cesium添加流动线

1&#xff1a;新建Spriteline1MaterialProperty.js文件 import * as Cesium from cesium;export function Spriteline1MaterialProperty(duration, image) {this._definitionChanged new Cesium.Event();this.duration duration;this.image image;this._time performance.…...

使用java自带的队列进行存取数据ArrayBlockingQueue 多线程读取ExecutorService

场景&#xff1a; 防止接收数据时处理不过来导致阻塞&#xff0c;使用ArrayBlockingQueue队列存储数据后&#xff0c;以多线程的方式处理数据 保证系统性能。 package com.yl.demo.main4;import java.text.SimpleDateFormat; import java.util.Date; import java.util.concurr…...

【音视频之SDL2】Windows配置SDL2项目模板

文章目录 前言 SDL2 简介核心功能 Windows配置SDL2项目模板下载SDL2编译好的文件VS配置SDL2 测试代码效果展示 总结 前言 在开发跨平台的音视频应用程序时&#xff0c;SDL2&#xff08;Simple DirectMedia Layer 2&#xff09;是一个备受欢迎的选择。SDL2 是一个开源库&#x…...

JavaScript 里的深拷贝和浅拷贝

JavaScript 里的深拷贝和浅拷贝 JS中数据类型分为基本数据类型和引用数据类型。 基本类型值指的是那些保存在栈内存中的简单数据段。包含Number&#xff0c;String&#xff0c;Boolean&#xff0c;Null&#xff0c;Undefined &#xff0c;Symbol。 引用类型值指的是那些保存…...

Oracle基础-集合

集合&#xff1a;两个结果集的字段个数和字段类型必须相同&#xff0c;才能使用集合操作。 --UNION 并集 重复行会去重 (SELECT A,B FROM DUAL UNION SELECT C,D FROM DUAL) UNION (SELECT A,B FROM DUAL UNION SELECT E,F FROM DUAL ); --UNION ALL 全集 包含所有记录 不去重…...

《浅谈如何培养树立正确的人工智能伦理观念》

目录 摘要&#xff1a; 一、引言 二、《机械公敌》的情节与主题概述 三、人工智能伦理与法律问题分析 1.伦理挑战 2.法律问题 四、培养正确的人工智能伦理观念的重要性 五、培养正确的人工智能伦理观念的途径与方法 1.加强教育与宣传 2.制定明确的伦理准则和规范 3.…...

uniapp实现局域网(内网)中APP自动检测版本,弹窗提醒升级

uniapp实现局域网&#xff08;内网&#xff09;中APP自动检测版本&#xff0c;弹窗提醒升级 在开发MES系统的过程中&#xff0c;涉及到了平板端APP的开发&#xff0c;既然是移动端的应用&#xff0c;那么肯定需要APP版本的自动更新功能。 查阅相关资料后&#xff0c;在uniapp的…...

【Golang 面试 - 进阶题】每日 3 题(六)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/UWz06 &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏…...

Unity横板动作游戏 -项目准备

项目准备 这是一篇 Unity 2022 最新稳定版本的教程同步笔记&#xff0c;本文将会讲解一些开始学习必须的条件。 安装环境 首先是安装 UnityHub&#xff0c;然后在 UnityHub 中安装 Unity 的版本(2022)。 只需要安装 开发者工具 和文档即可&#xff0c;导出到其他平台的工具等…...

基于Gunicorn + Flask + Docker的高并发部署策略

标题&#xff1a;基于Gunicorn Flask Docker的高并发部署策略 引言 随着互联网用户数量的增长&#xff0c;网站和应用程序需要能够处理越来越多的并发请求。Gunicorn 是一个 Python WSGI HTTP 服务器&#xff0c;Flask 是一个轻量级的 Web 应用框架&#xff0c;Docker 是一…...

jdk版本管理利器-sdkman

1.什么是sdkman&#xff1f; sdkman是一个轻量级、支持多平台的开源开发工具管理器&#xff0c;可以通过它安装任意主流发行版本&#xff08;例如OpenJDK、Kona、GraalVM等等&#xff09;的任意版本的JDK。通过下面的命令可以轻易安装sdkman: 2.安装 curl -s "https://…...

Kafka知识总结(事务+数据存储+请求模型+常见场景)

文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 事务 事务Producer保证消息写入分区的原子性&#xff0c;即这批消…...

C#中重写tospring方法

在C#中&#xff0c;重写ToString方法允许你自定义对象的字符串表示形式。当你想要打印对象或者在调试时查看对象的状态时&#xff0c;重写ToString方法非常有用。 默认情况下&#xff0c;ToString方法返回对象的类型名称。通过重写这个方法&#xff0c;你可以返回一个更有意义…...

【机器学习基础】机器学习的数学基础

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈Python机器学习 ⌋ ⌋ ⌋ 机器学习是一门人工智能的分支学科&#xff0c;通过算法和模型让计算机从数据中学习&#xff0c;进行模型训练和优化&#xff0c;做出预测、分类和决策支持。Python成为机器学习的首选语言&#xff0c;…...

fastapi之零

FastAPI 详细介绍 FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 web 框架&#xff0c;用于构建 API。它基于标准的 Python 类型提示&#xff0c;使用 Starlette 作为 web 框架&#xff0c;Pydantic 进行数据验证和解析。以下是对 FastAPI 的详细介绍&#xff0c…...

SpringBoot整合PowerJob 实现远程任务

PowerJob介绍 PowerJob 是全新一代分布式任务调度和计算框架&#xff0c;提供了可视化界面&#xff0c;可通过单机、远程等形式调用任务并提供了运行监控和日志查看的功能模块&#xff0c;是当前比较流行的分布式定时任务框架之一&#xff1b; PowerJob 官网文档地址 环境搭建…...

【扒模块】DFF

图 医学图像分割任务 代码 import torch import torch.nn as nnfrom timm.models.layers import DropPath # 论文&#xff1a;D-Net&#xff1a;具有动态特征融合的动态大核&#xff0c;用于体积医学图像分割&#xff08;3D图像任务&#xff09; # https://arxiv.org/abs/2403…...

frameworks 之Socket

frameworks 之Socket Socket服务端1.创建Socket。2.绑定socket3.监听socket4.等待客户端连接5.读取或者写入给客户端 客户端1.创建Socket。2.连接服务端Socket3.读取或者写入给客户端4.关闭socket 演示代码 Epoll创建Epoll添加或删除Epoll等待消息返回Epoll演示代码 SocketPair…...

WEB前端开发中如何实现大文件上传?

大文件上传是个非常普遍的场景&#xff0c;在面试中也会经常被问到&#xff0c;大文件上传的实现思路和流程。在日常开发中&#xff0c;无论是云存储、视频分享平台还是企业级应用&#xff0c;大文件上传都是用户与服务器之间交互的重要环节。随着现代网络应用的日益复杂化&…...

ts给vue中props设置指定类型

interface IBaseObject {[key: string | number]: any; }export default defineComponent({name:xx,props:{data:{type:Object as PropType<IBaseObject>,default:()>({}),required:true},}, })...

模拟实现c++中的list模版

☺☺☺☺☺☺☺☺☺☺ 点击 进入杀马特的主页☺☺​​​​​​​☺​​​​​​​☺​​​​​​​☺​​​​​​​☺​​​​​​​☺​​​​​​​☺​​​​​​​☺​​​​​​​☺ 目录 一list简述&#xff1a; 二库内常用接口函数使用&#xff1a; 1reverse(): 2.s…...

从信息论的角度看微博推荐算法

引言 在数字时代&#xff0c;推荐系统已成为社交媒体和其他在线服务平台的核心组成部分。它们通过分析用户行为和偏好&#xff0c;为用户提供个性化的内容&#xff0c;从而提高用户满意度和平台的参与度。推荐系统不仅能够增强用户体验&#xff0c;还能显著提升广告投放的效率…...

CISC(复杂指令集)与RISC(精简指令集)的区别

RISC(Reduced Instruction Set Computer)和CISC(complex instruction set computer)是当前CPU的两种架构。 它们的区别在于不同的CPU设计理念和方法。 早期的CPU全部是CISC架构&#xff0c;它的设计目的是要用最少的机器语言指令来完成所需的计算任务。比如对于乘法运算&#x…...

自定义数据库连接的艺术:Laravel中配置多数据库连接详解

自定义数据库连接的艺术&#xff1a;Laravel中配置多数据库连接详解 在现代Web应用开发中&#xff0c;经常需要连接到多个数据库。Laravel&#xff0c;作为PHP界最受欢迎的框架之一&#xff0c;提供了强大的数据库抽象层&#xff0c;支持多种数据库系统&#xff0c;并且允许开…...

力扣高频SQL 50题(基础版)第八题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第八题1581. 进店却未进行过交易的顾客题目说明思路分析实现过程准备数据&#xff1a;实现方式&#xff1a;结果截图&#xff1a;总结&#xff1a; 力扣高频SQL 50题&#xff08;基础版&#xff09;第八题 1581. 进店…...

【C++20】从0开始自制协程库

文章目录 参考 很多人对协程的理解就是在用户态线程把CPU对线程的调度复制了一遍&#xff0c;减少了线程的数量&#xff0c;也就是说在一个线程内完成对协程的调度&#xff0c;不需要线程切换导致上下文切换的开销。但是线程切换是CPU行为&#xff0c;就算你的程序只有一个线程…...

Docker 深度解析:从入门到精通

引言 在当今的软件开发领域&#xff0c;容器化技术已经成为一种趋势。Docker 作为容器化技术的代表&#xff0c;以其轻量级、可移植性和易用性&#xff0c;被广泛应用于各种场景。本文将从 Docker 的基本概念入手&#xff0c;详细介绍 Docker 的安装、基本操作、网络配置、数据…...