leetcode-----41. 缺失的第一个正数

代码

class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        int n = nums.size();
        if (n == 0) return 1;

        for (int i = 0; i < n; ++i) {
            while (nums[i] > 0 && nums[i] < n && nums[i] != nums[nums[i]]) {
                swap(nums[i], nums[nums[i]]);
            }
        }
        for (int i = 1; i < n; ++i) {
            if (nums[i] != i) return i;
        }
        return nums[0] == n ? n + 1 : n;
    }
};
posted @ 2020-07-06 15:44  景云ⁿ  阅读(132)  评论(0编辑  收藏  举报