@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

最新文章

  1. Unity3D移植到Windows phone8 遇到的点点滴滴
  2. gcc中__builtin_return_address和__VA_ARGS__
  3. Linux下rz命令使用的实例详解
  4. IOS详解TableView——内置刷新,EGO,以及搜索显示控制器
  5. 如何优雅的写一篇安利文-以Sugar ORM为例
  6. ftp 229
  7. MVC-内容详情页显示内容
  8. 解决qt5窗口不刷新(测试窗口类型,测试窗口属性)
  9. C#小数点位数处理方法
  10. 14.6.3.1 The InnoDB Buffer Pool
  11. Linux 下Tomcat启动Cannot find ./catalina.sh
  12. iOS开发 - 啰嗦讲解 Runloop
  13. CJOJ 免费航班
  14. 微服务(Microservices)和服务网格(Service Mesh)架构概念整理
  15. nuxt.js实战之window和document对象的使用
  16. Prolog 逻辑推导语言
  17. LRU原理和Redis实现——一个今日头条的面试题(转载)
  18. 自动化测试-6.selenium的css定位
  19. active在iphone上不起作用
  20. (三)HtmlUnit 实践

热门文章

  1. mysql/mariadb学习记录——创建删除数据库、表的基本命令
  2. 【转】SVG与HTML、JavaScript的三种调用方式
  3. 小白用linode VPS搭建wordpress博客过程备忘 | Linode中文教程
  4. 苏州Uber优步司机奖励政策(4月22日)
  5. 4539: [Hnoi2016]树
  6. kali base64命令的使用
  7. Ansible详解(一)基础安装和配置
  8. 【SoDiaoEditor电子病历编辑器更新啦】--谨以献给那些还在医疗行业奋斗的小伙伴们
  9. GGTalk——C#开源即时通讯系统源码介绍系列(一)
  10. XAF-由于try catch导致的性能问题一例