python数字排序 循环_【python-leetcode448-循环排序】找到所有数组中消失的数字

问题描述:

给定一个范围在  1 ≤ a[i] ≤ n ( n = 数组大小 ) 的 整型数组,数组中的元素一些出现了两次,另一些只出现一次。

找到所有在 [1, n] 范围之间没有出现在数组中的数字。

您能在不使用额外空间且时间复杂度为O(n)的情况下完成这个任务吗? 你可以假定返回的数组不算在额外空间内。

示例:

输入:

[4,3,2,7,8,2,3,1]

输出:

[5,6]

核心;循环排序法,让每个数字在其应该的位置上。注意数值和下标之间的关系

classSolution:def findDisappearedNumbers(self, nums: List[int]) ->List[int]:

res=[]

l=0

r=len(nums)-1

while l<=r:if nums[l] != nums[nums[l]-1]:

nums[nums[l]-1],nums[l] = nums[l],nums[nums[l]-1]else:

l+=1

for i inrange(len(nums)):if i+1 !=nums[i]:

res.append(i+1)return res

比如:nums=[4,3,2,7,8,2,3,1]

过程:

[7,3,2,4,8,2,3,1]

[3,3,2,4,8,2,7,1]

[2,3,3,4,8,2,7,1]

[3,2,3,4,8,2,7,1]

[2,3,3,4,8,2,7,1]

[2,3,3,4,1,2,7,8]

[1,3,3,4,2,2,7,8]

[1,2,3,4,3,2,7,8]

最后再遍历一次数组:值!=下标+1,将下标+1加入到结果中。

结果:

b629d513355a92fc32dbd83d9d78ea96.png

原文:https://www.cnblogs.com/xiximayou/p/12358903.html

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

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

相关文章

saiku+kettle整合(六)olap操作

title: saikukettle整合&#xff08;六&#xff09;olap操作 tags: categories: saiku date: 2016-08-25 18:18:54 使用saiku可以对应使用相关olap操作 OLAP的基本操作 我们已经知道OLAP的操作是以查询——也就是数据库的SELECT操作为主&#xff0c;但是查询可以很复杂&#xf…

携程Docker实践

原文地址&#xff1a;http://www.iteye.com/news/31468 请点击原文阅读 ---------------------以下是原文---------------------- 从去年底开始&#xff0c;携程开始计划把Docker引入到携程的云平台&#xff0c;这是系统研发部一部分的工作任务&#xff0c;携程系统研…

mysql全文索引thinkphp_ThinkPHP5 使用迅搜 (XunSearch) 实现全文检索实例指导

前期准备入坑了一天&#xff0c;折腾的无语&#xff0c;个人观点&#xff1a;【文档太差&#xff0c;适合学习思路&#xff0c;不建议入坑】背景最近在整理全文检索解决方案注意到 xunsearch 的评价很高&#xff0c;在此记录一番场景描述此处作为对 xunsearch 的初次使用&#…

为何有些程序员总是想要“干掉”产品经理?

好了&#xff0c;我准备去和产品经理做斗争去了&#xff0c;请祝我好运吧&#xff01;小编花了大量时间收集了很多干货编程学习资源&#xff0c;其中资源包括 算法&#xff0c;大数据&#xff0c;人工智能&#xff0c;Python&#xff0c;Android&#xff0c;iOS&#xff0c;Jav…

多个left join 产生多个结果

select a.*,to_char(To_date(20160403000000, yyyyMMddhh24miss),yyyy/mm/dd) as omc_start_time,to_char(To_date(20160404000000, yyyyMMddhh24miss),yyyy/mm/dd) as omc_end_time,ROUND(sc."切换成功率",2) AS "OMC-源小区切换成功率%",ROUND(sc."…

查看进程占用,并kill掉

今天发现8899端口被占&#xff0c;服务器启动失败&#xff0c;用了下面的命令解决。 [rootltesqm Toolbox]# netstat -tunlp |grep 8899 tcp 0 0 :::8899 :::* LISTEN 28279/java [rootltesqm Toolbox]…

Spark算子篇 --Spark算子之combineByKey详解

一。概念 rdd.combineByKey(lambda x:"%d_" %x, lambda a,b:"%s%s" %(a,b), lambda a,b:"%s$%s" %(a,b))三个参数&#xff08;都是函数&#xff09;第一个参数&#xff1a;给定一个初始值&#xff0c;用函数生成初始值。第二个参数&#xff1a;c…

mysql proxy 主从_【MYSQL知识必知必会】MySQL主从复制读写分离(基于mysql-proxy实现)...

MySQL主从复制读写分离(基于mysql-proxy实现)http://mirror.bit.edu.cn/mysql/Downloads/MySQL-Proxy/mysql-proxy-0.8.4-linux-glibc2.3-x86-64bit.tar.gz解压tar zxvf mysql-proxy-0.8.4-linux-glibc2.3-x86-64bit.tar.gz创建mysql-proxy帐号并授权分别在主从数据库中创建mys…

SecureCRT防止自动断开

今天在宁波连接上海的linux库&#xff0c;是外网访问内网&#xff0c;使用了nat123这个软件映射的。 发现SecureCRT连接后&#xff0c;过几分钟就自动断开&#xff0c;导致使用SecureCRT做跳转机的其他应用使用起来很不方便。 于是设置了下SecureCRT。

mysql 主主结构_高性能mysql主主架构

(3)配置参数说明server-id&#xff1a;ID值唯一的标识了复制群集中的主从服务器&#xff0c;因此它们必须各不相同。master_id必须为1到232–1之间的一个正整数值&#xff0c;slave_id值必须为2到232–1之间的一个正整数值。log-bin&#xff1a;表示打开binlog,打开该选项才可以…

解决ios编译swift报错pcm was built: mtime changed

问题 编译ios工程失败时&#xff0c;其中的几个swift文件报以下错 /Users/tomes/code/project/xxx.swift File /Users/tomes/Library/Developer/Xcode/DerivedData/Spec-dgyhrnmgvfkjkqbboklnfgrudqip/Build/Products/Debug-iphoneos/xxxx.framework/Headers/xxxx.h has been…

AI工程师职业规划和学习路线完整版

AI工程师职业规划和学习路线完整版 如何成为一名机器学习算法工程师 成为一名合格的开发工程师不是一件简单的事情&#xff0c;需要掌握从开发到调试到优化等一系列能 力&#xff0c;这些能力中的每一项掌握起来都需要足够的努力和经验。而要成为一名合格的机器学习算法工程师&…

oracle 多个with as

主要看多个with的格式 [sql] view plaincopy WITH T3 AS ( SELECT T1.ID, T1.CODE1, T2.DESCRIPTION FROM TB_DATA T1, TB_CODE T2 WHERE T1.CODE1 T2.CODE ), T4 AS ( SELECT T1.ID, T1.CODE2, T2.DESCRIPTION FROM TB_DATA T1, TB_CODE T2 WHERE T1.C…

mysql主键 命中率_mysql主键问题

MySQL主键一. MySQL主键设计原则MySQL主键应当是对用户没有意义的。MySQL主键应该是单列的&#xff0c;以便提高连接和筛选操作的效率(当然复合主键是可以的&#xff0c;只是不建议)永远也不要更新MySQL主键MySQL主键不应包含动态变化的数据&#xff0c;如时间戳、创建时间列、…

Centos7常用命令[挂载文件系统]

Centos7常用命令[挂载文件系统]------------------------------------------------------------------------------# 挂载一个叫做hda2的盘-确定目录/mnt/hda2已经存在[rootlocalhost ~]# mount /dev/hda2 /mnt/hda2# 卸载一个叫做hda2的盘-先从挂载点/mnt/hda2退出[rootlocalh…

hadoop SecondNamenode

一、定义 * The Secondary Namenode is a helper to the primary Namenode. * The Secondary is responsible for supporting periodic checkpoints * of the HDFS metadata. The current design allows only one Secondary * Namenode per HDFs cluster. * The Secondary Nam…

Tensorflow Python API 翻译(sparse_ops)

作者&#xff1a;chen_h 微信号 & QQ&#xff1a;862251340 微信公众号&#xff1a;coderpai 我的博客&#xff1a;请点击这里计划现将 tensorflow 中的 Python API 做一个学习&#xff0c;这样方便以后的学习。 原文链接该章介绍有关稀疏张量的API稀疏张量表示对于多维稀疏…

高性能mysql 小查询_高性能MySql进化论(十一):常见查询语句的优化

总结一下常见查询语句的优化方式1 COUNT1. COUNT的作用 COUNT(table.filed)统计的该字段非空值的记录行数 COUNT(*)或者是COUNT(not nullable field) 统计的是全表的行数如果要是统计全表记录数&#xff0c;COUNT(*)效率会比COUNT(not nullable fie…

ORA-01861: 文字与格式字符串不匹配

select to_date(20160401000000,yyyy-mm-dd) from dual; ---------- 报错&#xff1a;ORA-01861: 文字与格式字符串不匹配 原因&#xff1a;字符串20160401000000与要转换的格式 yyyy-mm-dd 格式不对。 20160401000000 是 yyyymmddhh24miss 格式的 -------- select to_da…

首席架构师徐海峰眼中的架构和出色的架构师

CSDN架构领域编辑采访了一些与会讲师&#xff0c;谈谈他们将在会上分享的内容、相关技术和程序人生&#xff0c;带你领略讲师风采。 本期我们采访的讲师是来自阅文集团首席架构师徐海峰&#xff0c;主要负责内容中心的网站架构和分布式存储、分布式计算工作。10年互联网开发经验…