当前位置: 首页 > news >正文

day-52 下一个排列

在这里插入图片描述
思路
从后向前遍历数组,把遍历过的元素加入一个有序链表,没变里一个元素判断链表中是否有元素大于当前遍历元素,如果有,把链表中大于当前遍历元素的元素集合中最小的那一个元素赋给当前元素,然后将链表中剩余元素依次赋值给当前遍历元素之后的元素

解题过程
如果输入数组已经是能组成最大的数,则数组升序排列再返回

Code

class Solution {public void nextPermutation(int[] nums) {int len=nums.length;List<Integer> list=new ArrayList<>();boolean flag=true;for(int i=len-1;i>=0;i--){list.add(nums[i]);Collections.sort(list);if(list.size()>0&&list.get(list.size()-1)>nums[i]){int id=list.size()-1;while(id>=0&&list.get(id)>nums[i]){id--;}nums[i]=list.get(id+1);list.remove(id+1);for(int j=i+1;j<len;j++){nums[j]=list.get(0);list.remove(0);}flag=false;}if(!flag) break;}if(flag)Arrays.sort(nums);}
}作者:菜卷
链接:https://leetcode.cn/problems/next-permutation/solutions/2912238/xia-yi-ge-pai-lie-by-ashi-jian-chong-dan-4ewp/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

http://www.mrgr.cn/news/23937.html

相关文章:

  • 向量——通俗地解释
  • 【Qt】Qt音频
  • ECOLOGY携带BearerToken后根据手机号码获取北森系统人员id
  • 数学建模笔记—— 多目标规划
  • 覆盖索引是什么意思?
  • 9.10总结
  • day10-配置文件日志多线程
  • 迟滞比较器/施密特触发器
  • Switch分支结构的细节
  • Python3中函数的用法
  • man命令学习记录
  • 大屏可视化:完美自适应的解决方案
  • 实战案例(2)防火墙+二交换机VLAN组网
  • 计算机毕业设计 家校互联管理系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试
  • strncpy陷阱
  • 后端开发面经系列--百度内容生态C++一面
  • 操作系统 --- 线程(Threads)概念 多线程模型 线程控制与组织
  • (Java企业 / 公司项目)点赞业务系统设计与完成
  • HAProxy--高性能反向代理
  • Windows远程桌面授权远程代码执行漏洞CVE-2024-38077(POC、EXP)