【算法 | 位运算No.1】leetcode268. 丢失的数字

news2025/1/19 3:17:05

个人主页:兜里有颗棉花糖
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创
收录于专栏【手撕算法系列专栏】【Leetcode】
🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望对大家有所帮助
🍓希望我们一起努力、成长,共同进步。

点击直接跳转到该题目

目录

  • 1️⃣题目描述
  • 2️⃣题目解析
  • 3️⃣解题代码

1️⃣题目描述

给定一个包含 [0, n]n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。

示例1:

输入:nums = [3,0,1]
输出:2
解释:n = 3,因为有 3 个数字,所以所有的数字都在范围 [0,3] 内。2 是丢失的数字,因为它没有出现在 nums 中。

示例2:

输入:nums = [0,1]
输出:2
解释:n = 2,因为有 2 个数字,所以所有的数字都在范围 [0,2] 内。2 是丢失的数字,因为它没有出现在 nums 中。

示例3:

输入:nums = [0,1]
输出:2
解释:n = 2,因为有 2 个数字,所以所有的数字都在范围 [0,2] 内。2 是丢失的数字,因为它没有出现在 nums 中。

示例4:

输入:nums = [0]
输出:1
解释:n = 1,因为有 1 个数字,所以所有的数字都在范围 [0,1] 内。1 是丢失的数字,因为它没有出现在 nums 中。

注意:

  • n == nums.length
  • 1 <= n <= 104
  • 0 <= nums[i] <= n
  • nums 中的所有数字都 独一无二

2️⃣题目解析

总共有三种解法(哈希、位运算、高斯求和)。

这里只对位运算高斯求和进行解释。

位运算求解原理:

  • 相同数组进行异或结果为0
  • 0 ^ num = num

高斯求和原理:

  • 把[0,n]的和记为sum1
  • 把数组nums中所有的元素之和记为sum2
  • 丢失的数字即为sum1 - sum2

3️⃣解题代码

解法1(高斯求和):

class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int n = nums.size(),sum1 = 0,sum2 = 0;

        for(int i = 0;i < n;i++) sum1 += nums[i];
        for(int i = 0;i <= n;i++) sum2 += i;

        return sum2 - sum1;   
    }
};

解法2(位运算):

class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int n = nums.size(),ret = 0;
        for(auto x : nums) ret ^= x;
        for(int i = 0;i <= n;i++) ret ^= i;
        return ret;
    }
};

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

打造一个开箱即用的超级丝滑的漂亮hexo博客网站

打造一个开箱即用的超级丝滑的漂亮hexo博客网站 目录 文章目录 打造一个开箱即用的超级丝滑的漂亮hexo博客网站目录文章持续更新地址鸣谢hexo简介hexo优缺点优点缺点&#x1f44e; 没有后台管理 博客效果主题特性版本迭代1.原版版本迭代2.自己版本迭代 贡献者主题下载&#x1f…

Python中if __name__ == ‘__main__‘

1. 在Python中&#xff0c;凡是以两个下划线开头&#xff0c;两个下划线结尾的变量叫做“魔法变量”。瓦特&#xff1f;魔法变量&#xff1f;对&#xff0c;你没有听错&#xff0c;就是魔法变量。所谓魔法变量就是Python对象内置天生就有的属性变量&#xff0c;你使用这些变量前…

开关电源测试方案介绍:如何进行电源耐压测试?

耐压测试是检验电源模块、电器设备等承受过压能力的测试方法&#xff0c;同时电源模块耐压测试还可以检测出设备的绝缘性能。在电气设备的使用过程中会出现电压突然上升的情况&#xff0c;有时也会因为天气原因出现高压&#xff0c;如果耐压性能弱&#xff0c;设备绝缘能力差&a…

【Java学习之道】SQL语言的基本语法与操作

引言 对于初学者来说&#xff0c;数据库编程可能听起来有些复杂&#xff0c;但实际上&#xff0c;只要掌握了SQL语言的基本语法和操作&#xff0c;你就能够轻松地处理各种数据问题。本章将为你揭示SQL语言的魅力&#xff0c;帮助你快速入门数据库编程。 一、SQL语言简介 SQL…

Three.js柏林噪音 流动球体

代码&#xff1a;https://gitee.com/honbingitee/three-template-next.js/tree/shader/ 参考油管视频&#xff1a;https://www.youtube.com/watch?voKbCaj1J6EI 核心&#xff1a; 创建循环的图形 应用噪声 顶点按照法相偏移 CustomMaterial(): ShaderMaterial {const material…

轻松上手,制作电子期刊就这么简单

嗨&#xff0c;年轻的朋友们&#xff01;你是否想过用你的创意和热情来制作一本属于自己的电子期刊&#xff1f;现在&#xff0c;这个梦想已经触手可及&#xff01;只需要用到这款工具即可轻松上手&#xff0c;就能拥有自己的电子期刊 工具&#xff1a;FLBOOK在线制作电子杂志平…

工具类app变现难?工具类产品广告变现策略实用指南

工具类app面临着买量成本高&#xff0c;收益提升难 的困境&#xff0c;在不同的变现周期可以采用不同的变现策略。#APP广告变现# 1、合理挖掘变现场景&#xff0c;提升eCPM 工具类 App 可基于自身产品属性和用户使用习惯路径&#xff0c;相应地选择开屏广告、信息流、横幅、…

品牌线上布局思路有哪些,品牌策略分析!

电商运营是现代企业宣推和销售产品的重要方式之一。要让品牌产品在电商节点&#xff0c;实现流量获取&#xff0c;就必须制定详细有效的品牌策略。今天为大家带来品牌线上布局思路有哪些&#xff0c;品牌策略分析&#xff01; 不同于线下销售广告&#xff0c;针对电商平台&…

浅谈压力测试的重要目标及意义

随着互联网应用的快速发展&#xff0c;软件系统的稳定性和性能成为了用户和企业关注的焦点。用户期望应用程序能够在高负载下依然保持稳定和高效。为了满足这一需求&#xff0c;压力测试成为了不可或缺的一环。本文将探讨压力测试的重要性以及如何进行压力测试。 一、压力测试的…

[正式学习java③]——字符串在内存中的存储方式、为什么字符串不可变、字符串的拼接原理,键盘录入的小细节。

一、字符串 1.字符串在内存中的存储方式 &#x1f525;在java中&#xff0c;内存中有两个地方可以存储字符串&#xff0c;一个是字符串池&#xff0c;一个是堆内存&#xff0c;串池中的字符串不会重复&#xff0c;而堆中的字符串每次都会开辟一块新的空间&#xff0c;因为维护…

Python武器库开发-基础篇(三)

基础篇(三) 函数 下面是一个打印问候语的简单函数&#xff0c;名为greet_user() &#xff1a; greeter.py def greet_user():"""显示简单的问候语"""print("Hello!")greet_user()这个示例演示了最简单的函数结构。第一行的代码行使…

优雅而高效的JavaScript——防抖和节流

&#x1f60a;博主&#xff1a;小猫娃来啦 &#x1f60a;文章核心&#xff1a;优雅而高效的JavaScript——防抖和节流 文章核心 引言事件处理的性能问题防抖&#xff1a;延迟触发事件基本原理实现防抖的代码示例实际应用场景举例 节流&#xff1a;限制事件触发频率基本原理实现…

传输层协议(TCP/UDP协议)

全文目录 端口号端口号范围划分 传输层UDP协议特点基于UDP的应用层协议 TCP协议确认应答机制&#xff08;可靠性&#xff09;延迟应答机制超时重传机制流量控制连接管理机制TIME_WAIT 状态CLOSE_WAIT 状态拥塞控制滑动窗口 TCP、UDP对比TCP的listen第二个参数 端口号 在套接字…

【算法设计zxd】第5章分治法

目录 分治算法策略的设计模式 分治思想&#xff1a; 分治算法求解问题的步骤&#xff1a; 设计模式 算法分析 二分查找算法 思考题 计算模型&#xff1a; 时间复杂度分析&#xff1a; 代码&#xff1a; 分治*大数乘法&#xff1a; 【例5-2】设X, Y是两个n位的十进制…

掌动智能分析云性能监控的重要性

云计算已成为现代企业的核心基础设施&#xff0c;它为企业提供了灵活性、可扩展性和成本效益。然而&#xff0c;将业务迁移到云上并不意味着问题就此消失。企业必须仍然保持对其云基础设施和应用程序的严格监控&#xff0c;以确保其性能和可靠性。本文将深入探讨企业云性能监控…

共享模型之管程

1、共享带来的问题 线程出现问题的根本原因是因为线程上下文切换&#xff0c;导致线程里的指令没有执行完就切换执行其它线程了&#xff0c;下面举一个例子 Test13.java static int count 0;public static void main(String[] args) throws InterruptedException {Thread t1 …

学习最优化课程中的一些疑惑

感谢gpt I: 你是一个数学专业教授&#xff0c;请给我讲解一下卡氏积的含义 GPT: 卡氏积&#xff08;Cartesian product&#xff09;是集合论中的一个概念&#xff0c;用来描述两个集合之间的关系。假设有两个集合A和B&#xff0c;卡氏积A B定义为所有有序对 (a, b)&#xf…

【Mysql】InnoDB数据页结构(五)

概述 页是InnoDB存储引擎管理存储空间的基本单位&#xff0c;一个页的大小默认是16KB 。InnoDB 为了不同的目的而设计了许多种不同类型的页 &#xff0c;比如存放记录的索引页&#xff0c;存放表空间头部信息的页&#xff0c;存放 Insert Buffer信息的页&#xff0c;存放 INOD…

23 种设计模式详解(C#案例)

&#x1f680;设计模式简介 设计模式&#xff08;Design pattern&#xff09;代表了最佳的实践&#xff0c;通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时…

力扣-消失的数字(两种方法)

题目内容&#xff1a; 方法1&#xff1a; 根据题目我们可以知道这个数组的内容是0~N的数字&#xff0c;而那个消失的数字就是也是这个0~n其中一个&#xff0c;那么我们可以得到0~N所有的数字之和后&#xff0c;再将数组中的数字全部减去&#xff0c;那么我们就得到了那个~消失…