Leetcode题库——31.下一个排列
2024-10-15 08:36:07
@author: ZZQ
@software: PyCharm
@file: nextPermutation.py
@time: 2018/11/12 15:32
要求:
实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。
如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。
必须原地修改,只允许使用额外常数空间。
以下是一些例子,输入位于左侧列,其相应输出位于右侧列。
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1
思路: 从数组尾部向前搜索,找到第一次nums[i] 比nums[i+1]小的位置,
将该位置i记录下来,然后将该位置之后的所有元素进行排列,找到比nums[i]大的第一个元素,将两数交换即可。
class Solution():
def __init__(self):
pass
def quickSort(self, list, left, right):
if left > right:
return
middle_value = list[left]
i = left
j = right
while i < j:
while i < j and list[j] >= middle_value:
j -= 1
while i < j and list[i] <= middle_value:
i += 1
if i < j:
t = list[i]
list[i] = list[j]
list[j] = t
list[left] = list[i]
list[i] = middle_value
self.quickSort(list, left, i-1)
self.quickSort(list, i+1, right)
def nextPermutation(self, nums):
"""
:type nums: List[int]
:rtype: void Do not return anything, modify nums in-place instead.
"""
nums_len = len(nums)
index = 0
small_value = -1
if nums_len == 0:
return nums
for i in range(nums_len-1):
if nums[nums_len-1-i-1] < nums[nums_len-1-i]:
index = nums_len-1-i
small_value = nums[nums_len-1-i-1]
break
if small_value == -1:
nums.sort(reverse=False)
return nums
self.quickSort(nums, index, nums_len-1)
for j in range(index, nums_len):
if nums[j] > small_value:
t = nums[j]
nums[j] = nums[index-1]
nums[index-1] = t
break
return nums
最新文章
- Unity3D移植到Windows phone8 遇到的点点滴滴
- gcc中__builtin_return_address和__VA_ARGS__
- Linux下rz命令使用的实例详解
- IOS详解TableView——内置刷新,EGO,以及搜索显示控制器
- 如何优雅的写一篇安利文-以Sugar ORM为例
- ftp 229
- MVC-内容详情页显示内容
- 解决qt5窗口不刷新(测试窗口类型,测试窗口属性)
- C#小数点位数处理方法
- 14.6.3.1 The InnoDB Buffer Pool
- Linux 下Tomcat启动Cannot find ./catalina.sh
- iOS开发 - 啰嗦讲解 Runloop
- CJOJ 免费航班
- 微服务(Microservices)和服务网格(Service Mesh)架构概念整理
- nuxt.js实战之window和document对象的使用
- Prolog 逻辑推导语言
- LRU原理和Redis实现——一个今日头条的面试题(转载)
- 自动化测试-6.selenium的css定位
- active在iphone上不起作用
- (三)HtmlUnit 实践
热门文章
- mysql/mariadb学习记录——创建删除数据库、表的基本命令
- 【转】SVG与HTML、JavaScript的三种调用方式
- 小白用linode VPS搭建wordpress博客过程备忘 | Linode中文教程
- 苏州Uber优步司机奖励政策(4月22日)
- 4539: [Hnoi2016]树
- kali base64命令的使用
- Ansible详解(一)基础安装和配置
- 【SoDiaoEditor电子病历编辑器更新啦】--谨以献给那些还在医疗行业奋斗的小伙伴们
- GGTalk——C#开源即时通讯系统源码介绍系列(一)
- XAF-由于try catch导致的性能问题一例