每日三题-下一个排列、颜色分类、寻找重复数

简介: 每日三题-下一个排列、颜色分类、寻找重复数

下一个排列


d1f2998dcc2f494399126583621a2cbf.png

解法一

双向遍历

先找出最大的索引 k 满足 nums[k] < nums[k+1],如果不存在,就翻转整个数组;

再找出另一个最大索引 l 满足 nums[l] > nums[k];

交换 nums[l] 和 nums[k];

最后翻转 nums[k+1:]。

class Solution {
    public void nextPermutation(int[] nums) {
        int len = nums.length;
        if(len <= 1) return;
        int index = -1;
        for(int i = len-1;i>0;i--){
            if(nums[i-1] < nums[i]){
                index = i-1;
                break;
            }
        }
        if(index == -1){ // 说明这是递减序列
            int left = 0;
            int right = len-1;
            while(left < right){
                int temp = nums[right];
                nums[right] = nums[left];
                nums[left] = temp;
                left++;
                right--;
            }
        }else{
            for(int i = len-1;i > index;i--){
                if(nums[i] > nums[index]){
                    int temp = nums[i];
                    nums[i] = nums[index];
                    nums[index] = temp;
                    Arrays.sort(nums,index+1,len);
                    return;
                }
            }
        }
        return;
    }
}

颜色分类


967fb25073af4a3cb6abcc1910548d44.png


方法一

排序

冒泡、快速等都可以

class Solution {
    public void sortColors(int[] nums) {
        int len = nums.length;
        if(len <= 1) return;
        int p0 = 0,p2 = len-1;
        for(int i = 0;i < len;i++){
            while(i <= p2 && nums[i] == 2){
                int t = nums[p2];
                nums[p2--] = nums[i];
                nums[i] = t;
            }
            if(nums[i] == 0){
                int t = nums[i];
                nums[i] = nums[p0];
                nums[p0++] = t;
            }
        }
        return;
    }
}

方法二

双指针

class Solution {
    public void sortColors(int[] nums) {
        int len = nums.length;
        if(len <= 1) return;
        int p0 = 0,p2 = len-1;
        for(int i = 0;i < len;i++){
            while(i <= p2 && nums[i] == 2){
                int t = nums[p2];
                nums[p2--] = nums[i];
                nums[i] = t;
            }
            if(nums[i] == 0){
                int t = nums[i];
                nums[i] = nums[p0];
                nums[p0++] = t;
            }
        }
        return;
    }
}


寻找重复数


6af33f911f95433e85869f91c5680cbf.png

解法一

原地Hash

将值为x的放到下标为x-1处

class Solution {
    public int findDuplicate(int[] nums) {
        // num[i] = i+1
        for(int i = 0;i < nums.length;i++){
            while(nums[i] != i+1){
                //值为nums[i]的应该放在nums[nums[i]-1] 处
                if(nums[i] == nums[nums[i]-1]) return nums[i];
                int t = nums[nums[i]-1];
                nums[nums[i]-1] = nums[i];
                nums[i] = t;
            }
        }
        return 0;
    }
}

解法二

快慢指针

class Solution {
    public int findDuplicate(int[] nums) {
        int slow = 0;
        int fast = 0;
        do{
            slow = nums[slow];
            fast = nums[nums[fast]];
        }while(slow != fast);
        slow = 0;
        while(slow != fast){
            slow = nums[slow];
            fast = nums[fast];
        }
        return slow;
    }
}


相关文章
|
3月前
|
算法 测试技术 C#
区间合并|LeetCode2963:统计好分割方案的数目
区间合并|LeetCode2963:统计好分割方案的数目
|
5月前
|
人工智能 算法
代码随想录算法训练营第三十五天 | LeetCode 435. 无重叠区间、763. 划分字母区间、56. 合并区间
代码随想录算法训练营第三十五天 | LeetCode 435. 无重叠区间、763. 划分字母区间、56. 合并区间
41 0
|
5月前
|
算法
代码随想录算法训练营第二十六天 | LeetCode 39. 组合总和、40. 组合总和 II、131. 分割回文串
代码随想录算法训练营第二十六天 | LeetCode 39. 组合总和、40. 组合总和 II、131. 分割回文串
30 0
|
6月前
代码随想录Day22 LeetCode T39 组合总和 T40 组合总和II T131 分割回文串
代码随想录Day22 LeetCode T39 组合总和 T40 组合总和II T131 分割回文串
20 0
|
10月前
|
算法 Java 网络架构
代码随想录训练营day27| 39. 组合总和 40.组合总和II 131.分割回文串
代码随想录训练营day27| 39. 组合总和 40.组合总和II 131.分割回文串
|
存储 算法
leetcode-每日一题1252. 奇数值单元格的数目(模拟优化)
时间复杂度:O(q * (m + n) + m * n) 其中q表示 indices 数组的长度,m、n为矩阵的行数和列数,遍历 indices 数组都要更新一次行列,总共需要O(q * (m + n))的时间,最后遍历一次矩阵,总共需要O(m * n)的时间
50 0
leetcode-每日一题1252. 奇数值单元格的数目(模拟优化)
代码随想录刷题|Leetcode 39. 组合总和 40.组合总和II 131.分割回文串
代码随想录刷题|Leetcode 39. 组合总和 40.组合总和II 131.分割回文串
代码随想录刷题|Leetcode 39. 组合总和 40.组合总和II 131.分割回文串
代码随想录刷题|LeetCode 435. 无重叠区间 763.划分字母区间 56. 合并区间
代码随想录刷题|LeetCode 435. 无重叠区间 763.划分字母区间 56. 合并区间
代码随想录刷题|LeetCode 435. 无重叠区间 763.划分字母区间 56. 合并区间
每日三题-旋转图像、合并区间、除自身以外数组的乘积
每日三题-旋转图像、合并区间、除自身以外数组的乘积
49 0
每日三题-旋转图像、合并区间、除自身以外数组的乘积
|
算法 索引
LeetCode每日一题——1252. 奇数值单元格的数目
给你一个 m x n 的矩阵,最开始的时候,每个单元格中的值都是 0。
61 0
LeetCode每日一题——1252. 奇数值单元格的数目

热门文章

最新文章