• 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--;
            }
        }
    }
    

      

  • 相关阅读:
    杭州电acm理工大舞台版
    String.Split()功能
    android layout物业介绍
    讨厌OpenSSL
    Android Bundle类别
    多项式回归
    如何直接串行电缆以及空调制解调器串行电缆之间的区别?
    为什么写科技博客是情侣如此重要?
    SSH框架总结(帧分析+环境结构+示例源代码下载)
    RapidXml用法
  • 原文地址:https://www.cnblogs.com/lvpengbo/p/15120816.html
Copyright © 2020-2023  润新知