算法面试真题详解:下一个排列

简介: 算法面试真题详解:下一个排列

给定一个整数数组来表示排列,找出其之后的一个排列。

在线评测地址:领扣题库官网

例1:

输入:[1]
输出:[1]
例2:
输入:[1,3,2,3]
输出:[1,3,3,2]
例3:
输入:[4,3,2,1]
输出:[1,2,3,4]

算法

  • 从后往前寻找不是递增的下标i
    从后往前遍历数组,如果一直是逐渐增大的,则已经是最大的了,如果出现了一个下降的数,那么遍历就到此为止,因为这已遍历的部分就可以排列成下一个较大的数了

发现找到 i为3 , a[3]=4就不是递增了
当找到这个突然下降的点A后,由于它后面已经排列为“最大”,因为A后面是完全降序的降序
在例子里 就是 7 6 5 3 2 降序

  • 然后从i 往后找到比下标i 对应的数字大的 且值最小的那个,令它为k,
    发现 k为6,a[6]=5 是比4大的,而且还是5还是最小的一个
  • 交换i k
    交换完毕 序列成了

1 11 12 5 7 6 4 3 2
这样的序列已经比原序列大了

  • 然后把从i+1到整个数组最后一个反转
  1. 11 12 5 2 3 4 6 7

这样既能保证比原序列大,而且i+1到结尾原本是降序的,说明是最大的排列,现在成了升序 i+1到结尾这一部分就成了最小的排列了
既能保证比原序列大,还尽可能的小,所以是原序列的下一个排列

  • 如果一直没有找到下降的点,则全部逆转即可。(从完全的降序改为了升序)

复杂度分析

时间复杂度
因为要遍历一遍数组 所以是O(N)的
空间复杂度
没有新开辟空间,所以还是O(N)

public class Solution {
    /**
     * @param nums: An array of integers
     * @return: nothing
     */
    public void nextPermutation(int[] nums) {
            int i=nums.length-2;
        while(i>=0&&nums[i]>=nums[i+1]){
                i--;
        }
        // i>=0 说明nums不是完全降序的 
        if(i>=0){
                //从i往后找,找到比i大的,且最小的那个 
                int j=i+1;
                while(j<nums.length&&nums[j]>nums[i]){
                        j++;
                }
                j--;
                // 交换i和j 
                int tmp=nums[i];
                nums[i]=nums[j];
                nums[j]=tmp;
        }
        //反转i之后的数组,让之前的从后往前的递增部分改成了从前往后递增,这样才能是下一个排列 
        i=i+1;
        int j=nums.length-1;
        while(i<j){
                int tmp=nums[i];
                nums[i]=nums[j];
                nums[j]=tmp;
                i++;
                j--;
        }
    }
}

更多题解参考:九章官网solution

相关文章
|
2天前
|
存储 算法 编译器
米哈游面试算法题:有效的括号
米哈游面试算法题:有效的括号
28 0
|
2天前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
64 1
|
2天前
|
负载均衡 算法 应用服务中间件
面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
字节跳动面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
45 0
|
17小时前
|
移动开发 算法 搜索推荐
2024最新Android算法相关面试大全,请查收
2024最新Android算法相关面试大全,请查收
|
2天前
|
存储 缓存 算法
面试遇到算法题:实现LRU缓存
V哥的这个实现的关键在于维护一个双向链表,它可以帮助我们快速地访问、更新和删除最近最少使用的节点,同时使用哈希表来提供快速的查找能力。这样,我们就可以在 O(1) 的时间复杂度内完成所有的缓存操作。哈哈干净利索,回答完毕。
|
2天前
|
算法 搜索推荐 Python
数据结构与算法在Python面试中的应用实例
【4月更文挑战第13天】本文聚焦Python面试中的数据结构与算法问题,包括排序算法、链表操作和树图遍历。重点讨论了快速排序、链表反转和二叉树前序遍历的实现,并指出理解算法原理、处理边界条件及递归操作是避免错误的关键。通过实例代码和技巧分享,帮助面试者提升面试表现。
13 0
|
2天前
|
设计模式 算法 Java
如何在面试中应对编程与算法面试?
面试中,编程能力至关重要,主要分为三个层次:初级关注基本功,如语法、原理和常见问题解决;高级涉及数据结构与算法,基础算法如排序对中小厂重要,大厂则需深入数据结构;资深专家层次需精通设计模式,以保证代码的扩展性和维护性。提升编程技能可采用PDCA循环学习法,从计划到执行、检查、行动不断迭代。通过实践项目如开发后端系统、测试框架来检验学习成果,并逐步学习算法和设计模式。坚持不懈的努力和重构将助你成为技术专家。记住,超越大多数人的关键在于持续学习和专注深耕。
8 0
如何在面试中应对编程与算法面试?
|
2天前
|
存储 移动开发 算法
面试时写不出排序算法?看这篇就够了
面试时写不出排序算法?看这篇就够了
93 0
|
2天前
|
算法
覃超老师 算法面试通关40讲
无论是阿里巴巴、腾讯、百度这些国内一线互联网企业,还是 Google、Facebook、Airbnb 等硅谷知名互联网公司,在招聘工程师的过程中,对算法和数据结构能力的考察都是重中之重。本课程以帮助求职者在短时间内掌握面试中最常见的算法与数据结构相关知识点,学会面试中高频算法题目的分析思路,同时给大家从面试官的角度来分析算法题的解答技巧,从而更有效地提升求职者的面试通过率。
16 3
覃超老师 算法面试通关40讲
|
2天前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解