zoukankan      html  css  js  c++  java
  • lc031: 下一个排列

    题目描述

    实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。必须原地修改,只允许使用额外常数空间。

    解法:

    /**
     * 下一个排列总是会比上一个排列大,除非该排列已经是最大的排列
     * 我们找到一个比当前排列大的一个新序列,且变化的幅度尽可能小
     * 1:将左边的一个较小数与右边的一个较大数交换,让当前排列变大
     * 2:同时要让这个较小数尽量靠右,较大数尽可能小
     * 3:交换完成后,这个较大数右边的数需要重新按照升序排列
     */
    // @lc code=start
    class Solution {
        public void nextPermutation(int[] nums) {
            int i = nums.length - 2;
            //找到较小数的位置i
            while (i >= 0 && nums[i] >= nums[i + 1]) {
                i--;
            }
            //找到较大数的位置j
            if(i >= 0) {
                int j = nums.length - 1;
                while (j >= 0 && nums[i] >= nums[j]) {
                    j--;
                }
                swap(nums, i, j);
            }
            reverse(nums, i + 1);
        }
    
        public void swap(int[] nums, int i, int j) {
            int temp = nums[i];
            nums[i] = nums[j];
            nums[j] = temp;
        }
    
        public void reverse(int[] nums, int start) {
            int left = start;
            int right = nums.length - 1;
            while (left < right) {
                swap(nums, left, right);
                left++;
                right--;
            }
        }
    }
    

      

  • 相关阅读:
    随性
    PHP csv文件处理时中文转码
    content...
    macro
    docker Alpine 编译安装node.js的dockerfile文件
    docker hub登录不上一直卡的原因
    java接口与模式(观察者)
    java模式的一点感受
    编码原则之接口隔离
    如何获取web应用的部署路径(多种方式)
  • 原文地址:https://www.cnblogs.com/lvpengbo/p/15120816.html
Copyright © 2011-2022 走看看