LeetCode 41.缺失的第一个正数

41.缺失的第一个正数

在这里插入图片描述
思路:1.题目目标是找缺失的第一位正整数indexx,也就是说indexx>=1&&indexx<=n+1。
2.希望在0(n)的时间复杂度下解决,那么我们就需要用到数组空间去换取时间。而题目要求“只使用常数级别额外空间的解决方案”,那么我们的目标就瞄准原始数组nums,在nums上进行处理,来达到要求。
3.先遍历一遍,把nums[i]<=0和nums[i]>lens的数都置为-1,表示无效的数。
4.再遍历一遍,对于nums[i]!=-1的数进行处理,详细处理流程看注释

class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        int lens=nums.size();
        for(int i=0;i<lens;i++){
            if(nums[i]<=0||nums[i]>lens) nums[i]=-1;//-1表示无效的数
        }
        for(int i=0;i<lens;i++){
            if(nums[i]>0){
            	//-1的目的是因为数组nums的小标是从-1开始的,为了避免当nums[i]=lens的情况造成数组下标越界的情况发生。
                int t=nums[nums[i]-1];//下标原来的值进行保存
                nums[nums[i]-1]=0;//0表示该值nums[i]-1(下标)存在
                while(t>0){//对下标原来的值进行处理
                    if(nums[t-1]!=0){//符合要求但还没标记就进行标记
                        int tmp=nums[t-1];
                        nums[t-1]=0;
                        t=tmp;
                    }else break;
                }
            }       
        }
        int indexx=0;
        for(int i=0;i<lens;i++){
            if(nums[i]!=0){
                indexx=i+1;
                break;
            }
        }
        if(indexx==0) indexx=lens+1;
        return indexx;
    }
};
  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值