加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

【LeetCode篇】 First Missing Positive

发布时间:2020-12-15 01:13:30 所属栏目:C语言 来源:网络整理
导读:【LeetCode篇】 First Missing Positive @(LeetCode) IDE: C++ (C) author : MinRam(minfysui@gmail.com) create : 03/19/2019 update: 03/19/2019 [toc] 题目 English : Given an unsorted integer array,find the smallest missing positive integer. Your

【LeetCode篇】 First Missing Positive

@(LeetCode)


  • IDE: C++ (C)
  • author : MinRam(minfysui@gmail.com)
  • create : 03/19/2019
  • update: 03/19/2019

[toc]


题目

  • English: Given an unsorted integer array,find the smallest missing positive integer.
Your algorithm should run in O(n) time and uses constant extra space.

思路

大体思路,简易桶。 Num[Value -1 ] = Value

  1. 判断Current是否满足一下情况,若满足则2,反之3

    • 正数
    • 小于答案的最大值 $(所求的正数 leq 数组长度)$
  2. CurrentNum[Current - 1] 交换。
  3. 下一位,重复1,直到数组遍历结束。

Alt text

代码实现

class Solution {
public:
int firstMissingPositive(vector& nums) {
int numsLen = nums.size();
for (int i = 0 ; i < numsLen; ){
if (nums[i] != (i + 1) && nums[i] >= 1 && nums[i] <= numsLen && nums[nums[i] - 1] != nums[i])
swap(nums[i],nums[nums[i] - 1]);
else
++i;
}
for (int i = 0; i < numsLen; ++i)
if (nums[i] != (i + 1))
return i + 1;
return numsLen + 1;
}
};


参考

[1]

反馈与建议

  • E-mail:
  • Q Q:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读