博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode 41. First Missing Positive
阅读量:4419 次
发布时间:2019-06-07

本文共 1514 字,大约阅读时间需要 5 分钟。

 

Given an unsorted integer array, find the first missing positive integer.

For example,

Given [1,2,0] return 3,
and [3,4,-1,1] return 2.

Your algorithm should run in O(n) time and uses constant space.

 

题意: 给定一个数组,返回不在数组中的最小的正整数。

要求O(n)的复杂度和O(1)的空间复杂度。

思路:

首先明显有:答案不会大于数组的长度+1。 (最大的情况是所有的数是从1-n的一个排列,则结果为n+1)。

为了在O(n)的时间中求出答案,我们理论上本来可以使用一个数组bool app[i]来表示i + 1是否出现,并且只保留1-n的数(原因如上述,答案不会超过n+1)。在O(N)的时间处理完以后,再从0 ~ n-1看app[i]是否为true。

现在要求空间也为常数,则我们考虑利用原数组进行上面的事情。

遍历一次数组,若nums[i]不为正数或者大于数组长度,则无视这些值。对于nums[i]-1 > i的i(也就是,要修改未来遍历的值),我们交换i和nums[i]-1 两个位置(这都是下标)的数,直到本条件不满足。

 

注意: 

1. 为什么要交换 : 因为不能确定nums[nums[i]-1 ]是否也会修改之后遍历的位置。

2. 判定条件要加一个nums[i] != nums[nums[i]-1]  否则对于[2,2]这种情况会陷入循环。

 

code:

class Solution {public:    int firstMissingPositive(vector
& nums) { int len = nums.size(); if(len == 0) return 1; for(int i = 0; i < len; i++){ if(nums[i] <= 0 || nums[i] > len) continue; // put 1 - > 0, so put nums[i] to nums[i] - 1 while(nums[i] - 1 > i && nums[nums[i]-1] != nums[i]){ // will change element in it's right side int tp = nums[nums[i] - 1]; nums[nums[i] - 1] = nums[i]; if(tp <= 0 || tp > len) break; nums[i] = tp; } nums[nums[i] - 1] = nums[i]; } for(int i = 0; i < len; i++){ if(nums[i] != i + 1) return i+1; } return len + 1; }};

 

转载于:https://www.cnblogs.com/bbbbbq/p/7622822.html

你可能感兴趣的文章
响应式网站对百度友好关键
查看>>
洛谷P2179 骑行川藏
查看>>
(十八)js控制台方法
查看>>
VB关键字总结
查看>>
android代码生成jar包并混淆
查看>>
一个不错的vue项目
查看>>
屏蔽指定IP访问网站
查看>>
python学习 第一天
查看>>
根据毫秒数计算出当前的“年/月/日/时/分/秒/星期”并不是件容易的事
查看>>
python的图形模块PIL小记
查看>>
shell变量子串
查看>>
iOS的主要框架介绍 (转载)
查看>>
react报错this.setState is not a function
查看>>
poj 1183
查看>>
从根本解决跨域(nginx部署解决方案)
查看>>
javascript实现的一个信息提示的小功能/
查看>>
Centos7.x:开机启动服务的配置和管理
查看>>
HTML5 浏览器返回按钮/手机返回按钮事件监听
查看>>
xss
查看>>
iOS:百度长语音识别具体的封装:识别、播放、进度刷新
查看>>