LeetCode 41. First Missing Positive(缺失的第一个正数)

题目

在这里插入图片描述
题目补充说明:这题中输入的数据中可以有负值,可以有重复的值,其中真正需要的排序效果是1,2,3,4…n这样的效果,让在这些数据之间找到缺失的第一个正数。

解析

分析:在明确了题目的实际要求之后,就可以设计算法了,比如如何处理负数和重复的数据,如何满足题目对于时间复杂度和空间复杂度的要求,时间复杂度要求只能遍历一遍,空间复杂的决定了算法中只能使用常数变量而不能使用HashMap。于是我的思路是先快排,让数组基本有序,然后用常数k来保存下一个应该出现的数字,找到就继续找下一个,找不到就返回这个数。
算法实现
算法中滤掉了非正数和重复数,实现线性查找数据。如果比对中各个数都存在,那么最后依然是返回累加后的k值。

class Solution {			
    public int firstMissingPositive(int[] nums) {
    	     int k=1;
    	     Arrays.sort(nums);
             for(int i=0;i<nums.length;i++){
            	 if(nums[i]<=0){
            		 continue;
            	 }
            	 if(i>0&&nums[i]==nums[i-1]){
            		 continue;
            	 }
            	 if(nums[i]!=k){
            		 return k;
            	 }
            	 k++;
             }
             return k;
    }    
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值