码迷,mamicode.com
首页 > 其他好文 > 详细

* 41. First Missing Positive

时间:2019-04-23 12:30:29      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:str   missing   leetcode   color   参考   lan   下标   public   https   

1. 原始题目

给定一个未排序的整数数组,找出其中没有出现的最小的正整数。

示例 1:

输入: [1,2,0]
输出: 3

示例 2:

输入: [3,4,-1,1]
输出: 2

示例 3:

输入: [7,8,9,11,12]
输出: 1

 

2. 思路---交换法

第一遍遍历:对于数组每个>=1的元素(正整数)且大小小于数组长度的元素都要交换位置以确保其在数组中的位置正确。

第二遍遍历:如果当前元素的位置不正确则返回该元素大小+1,否则遍历结束后返回数组长度+1。

具体过程参考博客

 

nums = [ 3 4 -1 1 8 ]

 

nums [ 0 ] 等于 3,把 3 放到第 3 个位置,并且把之前第 3 个位置的 -1 放回来,更新 nums [ -1, 4, 3, 1, 8 ]。

 

然后继续判断(循环判断)交换回来的数字,nums [ 0 ] 等于 -1,不是正数,忽略。

 

nums [ 1 ] 等于 4,把 4 放到第 4 个位置,并且把之前第 4个位置的 1 放回来,更新 nums [ -1, 1, 3, 4, 8 ]。

 

然后继续判断交换回来的数字,nums [ 1 ] 等于 1,把 1 放到第 1 个位置,并且把之前第 1 个位置的 -1 放回来,更新 nums [ 1, -1, 3, 4, 8 ]。

 

然后继续判断交换回来的数字,nums [ 1 ] 等于 -1,不是正数,忽略。

 

nums [ 2 ] 等于 3,刚好在第 3 个位置,不用管。

 

nums [ 3 ] 等于 4,刚好在第 4 个位置,不用管。

 

nums [ 4 ] 等于 8,我们的 nums 数组只能存 1 到 5,所以同样忽略。

 

最后,我们只需要遍历 nums 数组,遇到第一次 nums [ i ] != i + 1,就说明缺失了 i + 1。因为我们的 nums 数组每个位置都存着比下标大 1 的数。

 

代码:

 1 class Solution {
 2 public:
 3     int firstMissingPositive(vector<int>& nums) {
 4         for (int i = 0; i<nums.size(); i++){
 5             while ((nums[i] >0) && (nums[i] < nums.size() && (nums[i] != nums[nums[i] - 1]))){  # 注意while
 6                 swap(nums, i, nums[i] - 1);                       # 循环判断处理交换后的位置
 7             }
 8             
 9         }
10         for (int i = 0; i<nums.size(); i++)
11             if (nums[i] != i+1)
12                 return i+1;
13         return nums.size()+1;
14     }
15 
16     void swap(vector<int>&nums, int i, int j){
17         int temp = nums[i];
18         nums[i] = nums[j];
19         nums[j] = temp;
20     }
21 };

 

 

* 41. First Missing Positive

标签:str   missing   leetcode   color   参考   lan   下标   public   https   

原文地址:https://www.cnblogs.com/king-lps/p/10755607.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!