DS相关题目

news/2024/11/20 13:40:32/

DS相关题目

题目一:消失的数字

在这里插入图片描述

  • 拿到这道题目之后,首先可以想到的一个解题方法就是,我们可以先排序,排完序之后,这个数组其实就是一个有序的数组了,那只用比较数组中的每一个元素和他对应的下标是不是相等的,如果是相等的,那么就说明对应的数字其实是存在的,如果是不相等的,那么就说明对应的数字其实就是不存在的了,但是如果要排序的话,使用sort方法就不符合题目中说的时间复杂度为O(n)了,但是在leetcode上还是可以通过编译的,代码如下
class Solution {
public:int missingNumber(vector<int>& nums) {int i=0;sort(nums.begin(),nums.end());for(i=0;i<nums.size();i++){if(nums[i]==i)continue;elsereturn i;}return i;}
};
  • 解决这道题目的第二个思路其实就是位运算里面的异或,数组中有n个数,在这n个数的后面添加从0到n的每个整数,则添加了n+1个整数,共有2n+1个整数,在2n+1个整数中,消失的数字只在后面n+1个整数中出现一次,其余的数字在前 n个整数中(即数组中)和后面n+1个整数中各出现一次,即其余的数字都出现了两次。根据出现的次数的奇偶性,可以使用按位异或运算得到消失的数字。0和任何数字异或都是那个数字本身。由于2n+1个整数中,消失的数字出现了一次,其余的数字都出现了两次,因此对上述 2n+1个整数进行按位异或运算,结果就是消失的数字
class Solution {
public:int missingNumber(vector<int>& nums) {int ret=0;for(int i=0;i<nums.size();i++){ret^=nums[i];}for(int i=0;i<=nums.size();i++){ret^=i;}return ret;}
};
  • 第三种思路就是进行两个数字的做差,就可以求出来那个消失的数字
class Solution {
public:int missingNumber(vector<int>& nums) {int n=nums.size();      int ret=ret=(1+n)*n/2;;for(int i=0;i<n;i++){ret-=nums[i];}return ret;}
};

http://www.ppmy.cn/news/1112803.html

相关文章

阿里云服务器上CentOS 7.6使用rpm包安装MySQL 8.0.31

我这里下载的是最新版本&#xff0c;需要到MySQL官网最新版本下载地址。 要是想要下载以前的版本需要到MySQL以前版本网址中。 1&#xff09;先使用wget https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.31-1.el7.x86_64.rpm-bundle.tar&#xff08;这个网址现在已经不…

欧拉定理公式(包括欧拉降幂)

欧拉定理 a b ≡ { a b m o d φ ( p ) , gcd ⁡ ( a , p ) 1 a b , gcd ⁡ ( a , p ) ≠ 1 , b < φ ( p ) ( m o d p ) a b m o d φ ( p ) φ ( p ) , gcd ⁡ ( a , p ) ≠ 1 , b ≥ φ ( p ) a^{b}\equiv\left\{\begin{array}{ll} a^{b \bmod \varphi(p)}, & \ope…

Python项目Flask ipv6双栈支持改造

一、背景 Flask 是一个微型的(轻量)使用Python 语言开发的 WSGI Web 框架(一组库和模块),基于Werkzeug WSGI工具箱/库和Jinja2 模板引擎,当然,Python的WEB框架还有:Django、Tornado、Webpy,这暂且不提。 Flask使用BSD授权。 Flask也被称为microframework(微框架),F…

C【动态内存管理】

1. 为什么存在动态内存分配 int val 20;//在栈空间上开辟四个字节 char arr[10] {0};//在栈空间上开辟10个字节的连续空间 2. 动态内存函数的介绍 2.1 malloc&#xff1a;stdlib.h void* malloc (size_t size); int* p (int*)malloc(40); #include <stdlib.h> #incl…

c# 面试题

简述 private、 protected、 public、 internal 修饰符的访问权限。 答&#xff1a; Private&#xff08;拍非得&#xff09; : 私有成员, 在类的内部才可以访问。 protected &#xff08;普泰忒&#xff09;: 保护成员&#xff0c;该类内部和继承类中可以访问。 Publ…

514. 自由之路

514. 自由之路 class FindRotateSteps:"""514. 自由之路https://leetcode.cn/problems/freedom-trail/"""def solution(self, ring: str, key: str) -> int:m, n len(ring), len(key)# 字符 -> 索引列表self.charToIndex dict()self.mem…

蓝桥杯 题库 简单 每日十题 day2

01 卡片 题目描述 本题为填空题&#xff0c;只需要算出结果后&#xff0c;在代码中使用输出语句将所填结果输出即可。 小蓝有很多数字卡片&#xff0c;每张卡片上都是数字 0 到 9。 小蓝准备用这些卡片来拼一些数&#xff0c;他想从 1 开始拼出正整数&#xff0c;每拼一个&a…

网络安全(黑客)自学​

前言 作为一个合格的网络安全工程师&#xff0c;应该做到攻守兼备&#xff0c;毕竟知己知彼&#xff0c;才能百战百胜。 计算机各领域的知识水平决定你渗透水平的上限。 【1】比如&#xff1a;你编程水平高&#xff0c;那你在代码审计的时候就会比别人强&#xff0c;写出的漏洞…