面试中的算法(查找缺失的整数)

     在一个无序数组里有99个不重复的正整数,范围是1~100,唯独缺少1个1~100中的整数。如何找出这个缺失的整数?

      一个很简单也很高效的方法,先算出1~100之和,然后依次减去数组里的元素,最后得到的差值,就是那个缺失的整数。

假设数组长度是n,那么该解法的时间复杂度是O (n),空间复杂度是O (1)。

import random
#数组
def find_1(n):ll=[]#随机生成1-n的一个数作为缺失数rd= random.randint(1,n+1)# print(rd)#循环数据for i in range(1,n+1):if i!=rd:ll.append(i)print(ll)return ll#查找缺失的整数
def find_number(n):ll=find_1(n)#累计和sum1=sum(ll)#累计1..n和sum2=((1+n)*n)//2print(sum1,sum2)return sum2-sum1if __name__ == '__main__':# print(find_number(10))print(find_number(100))

 

扩展题1:

一个无序数组里有若干个正整数,范围是1~100,其中99个整数都出现了偶数次,只有1个整数出现了奇数次,如何找到这个出现奇数次的整数?

     遍历整个数组,依次做异或运算。由于异或运算在进行运算时,相同为0,不同为1,

     因此所有出现偶次的整数都会相互抵消成为0,只有唯一出现奇数的整数会被留下。

 

def find2(ll):lost=0for i in range(len(ll)):#异或运算lost=lost^ll[i]return lostif __name__ == '__main__':ll=[3,1,3,2,2,8,1]print(find2(ll))

如果数组长度为n,该解法的时间复杂度是O(n),空间复杂度为O(1)。 

 扩展题2:

假设一个无序数组里有若干个正整数, 范围是1~ 100, 其中有98个整数出现了偶数次, 只有2个整数出现了奇数次, 如何找到这2个出现奇数次的整数?

使用分治算法,设这两个整数为A,B。

1、先将数组内元素异或得到A,B的异或值。

2、将该值对应的二进制位从右至左找到第一个为1的值sep,表示A,B对应的二进制表示在此处的位置相异,设A为1,B为0。

3、利用此区别,将数组中的其他元素和sep相与,为1和A划为一组,为0和B划为一组。

4、利用扩展1求解。

def find3(ll):# 用于存储两个出现奇数次的整数result=[0,0]# 第一次整体异或lost = 0for i in range(len(ll)):# 异或运算lost = lost ^ ll[i]# 如果异或结果为0,说明输入数组不符合题目if lost==0:raise ValueError# 确定两个整数的不同位,以此来做分组sep=1while lost & sep==0:sep<<=1# 第二次分组异或for i in range(len(ll)):if ll[i] & sep==0:result[0]^=ll[i]else:result[1]^=ll[i]return resultif __name__ == '__main__':ll=[3,1,3,2,2,8,1,4]print(find3(ll))

 

如果数组长度是n,该解法的时间复杂度是O(n)。把数组分成两部分,并不需要借助额外的存储空间,完全可以在按二进制位分组的同时来做异或运算,所以空间复杂度仍然是O(1)

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

11个免费的 android数据恢复应用程序功能分析

在手机上丢失数据是一个很大的错误。但是&#xff0c;在这种情况下&#xff0c;除了惊慌失措之外&#xff0c;最好开始使用android数据恢复应用程序搜索以查找将其取回的方法。您可以检查手机的备份存储以在Android上进行数据恢复&#xff0c;但是如果数据仍然无处可寻&#xf…

每日一题:最大加号标志

在一个 n x n 的矩阵 grid 中&#xff0c;除了在数组 mines 中给出的元素为 0&#xff0c;其他每个元素都为 1。mines[i] [xi, yi]表示 grid[xi][yi] 0 返回 grid 中包含 1 的最大的 轴对齐 加号标志的阶数 。如果未找到加号标志&#xff0c;则返回 0 。 一个 k 阶由 1 组…

数据结构(二) 线性表

2024年5月13日一稿 线性表的定义与基本操作 数据类型相同(各个元素占用空间相同) 是有限序列 基操

【Jenkins】Pipeline流水线语法解析全集 -- 声明式流水线

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;CSDN博客专家   &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01…

测试平台开发之测试框架改造并发执行及结果隔离(1)

1、准备测试框架 接口测试框架&#xff1a;api_framework.zipUI测试框架 1、当拿到上面这个zip文件之后需要进行解压&#xff0c;解压到这里 2、安装依赖 在解压后的这个项目路径下面新建一个requirements.txt 接下来通过pdm照着requirements里面的库进行安装 pdm add allu…

GPT-4o--真AI助手来临,可免费使用!

​ 今天凌晨&#xff0c;OpenAI又双缀缀发大招了&#xff0c;直接放出新的模型–GPT-4o&#xff0c;并号称可以实时对音频、视觉和文本进行推理。现场直播效果非常炸裂&#xff0c;能听、说、看&#xff0c;而且几乎没有延迟。 在GPT-4o出来以前&#xff0c;GPT也有语音对话功…

智慧畜牧:RFID技术在现代屠宰场的应用

智慧畜牧&#xff1a;RFID技术在现代屠宰场的应用 RFID猪肉溯源管理解决方案是一种利用无线射频识别&#xff08;Radio Frequency Identification&#xff0c;简称RFID&#xff09;技术来实现猪肉从养殖、屠宰到销售整个供应链过程中的追踪与追溯的现代化管理手段。这一方案通…

Windows Qt中支持heic 图片显示

安装vcpkg&#xff1a; git clone https://github.com/microsoft/vcpkg 执行脚本&#xff1a; .\vcpkg\bootstrap-vcpkg.bat 在安装之前如果需要指定vs的编译器&#xff0c; 在如下文件中做更改&#xff0c; 我指定的是用vs2019编译的&#xff1a; D:\vcpkg\vcpkg\triplets 增…

LeetCode 0994.腐烂的橘子:广度优先搜索(BFS)

【LetMeFly】994.腐烂的橘子&#xff1a;广度优先搜索(BFS) 力扣题目链接&#xff1a;https://leetcode.cn/problems/rotting-oranges/ 在给定的 m x n 网格 grid 中&#xff0c;每个单元格可以有以下三个值之一&#xff1a; 值 0 代表空单元格&#xff1b;值 1 代表新鲜橘子…

vue+vant项目0-1快速发布到--钉钉应用

uniapp开发笔记----vue开发项目配置钉钉应用 一、 vuevant开发项目1. 自定义vuevant项目或者已经有的旧项目1. 自定义vuevant项目1. 创建vue项目2. 安装依赖3. 引入所有组件4. 使用一个组件/效果和代码如下&#xff1a; 2. git官网仓库&#xff0c;直接拉默认dome代码3. 打包项…

RS8551XF功能和参数介绍及PDF资料

RS8551XF是Runic&#xff08;润石&#xff09;公司生产的一款精密运算放大器。以下是关于RS8551XF的一些技术参数和特点&#xff1a; 类型&#xff1a;精密运算放大器 品牌&#xff1a;Runic&#xff08;润石&#xff09; 输入偏置电流&#xff1a;极低&#xff08;适合精密测量…

GRFB-UNet:一种新的多尺度注意力网络,用于铺路分割

不同场景下的带注释的触觉铺装示例: GRFB-UNet网络结构: GRFB模块的结构: 铺路在视障人士的旅行中起着至关重要的作用。因此,识别铺装的形状和位置以支持视障人士的移动性是相当有意义的,而视觉分割技术就适合这项任务。为了有效提高触觉铺装分割的精度和鲁棒性,…