博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【leetcode】41. First Missing Positive 求不在给定数组里的最小的正整数
阅读量:6813 次
发布时间:2019-06-26

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

1. 题目

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.

2. 思路

遍历找到所有的正数,并建立hashmap。

同时记录下遍历过程中找到的第一个未验证的最小不存在正数起点。
然后从这个点开始每次递增1的在hashmap中验证是否存在。最多只会验证“正数的个数”次。
即复杂度O(N)

3. 代码

耗时:6ms

class Solution {public:    // 1. 第一遍找到正数的最小值的某一个局部最优起始位, 同时建立hashmap    // 2. 从最小值开始递增1的查找是否存在,最多只会查找“整数的个数个”    int firstMissingPositive(vector
& nums) { unordered_set
set; int start = 1; //int count = 0; for (int i = 0; i < nums.size(); i++) { int iv = nums[i]; if (iv <= 0) continue; //++count; set.insert(iv); if (iv == start) { start++; } } while (true) { if (set.find(start) != set.end()) { ++start; continue;; } else { break; } } return start; }};

转载地址:http://vqzzl.baihongyu.com/

你可能感兴趣的文章
iOS开发--动画篇之layout动画深入
查看>>
WorldWind源码剖析系列:视景体类Frustum
查看>>
(转)完整java开发中JDBC连接数据库代码和步骤
查看>>
Redis Lua脚本原理
查看>>
有时间测试dism
查看>>
/Users/alamps/AndroidStudioProjects/Demo10ScrollView
查看>>
【Swift】iOS UICollectionView 计算 Cell 大小的陷阱
查看>>
为什么我刚发表的文章变成了“待审核”,csdn有没有官方解释啊
查看>>
Matplotlib 工具包 使用教程索引
查看>>
深入学习TypeScript
查看>>
calico网络模型中的路由原理
查看>>
AutoScaling 弹性伸缩附加与分离RDS实例
查看>>
冒泡事件
查看>>
Spring Cloud Config采用Git存储时两种常用的配置策略
查看>>
PLook——记录你的知识
查看>>
css布局基础总结
查看>>
如何成为一位「不那么差」的程序员
查看>>
深入理解计算机系统读书笔记
查看>>
前端开发工作一年小记
查看>>
Java知识点总结(Java容器-TreeSet)
查看>>