码迷,mamicode.com
首页 > 编程语言 > 详细

[LeetCode]题解(python):031-Next Permutation

时间:2015-11-27 21:53:57      阅读:219      评论:0      收藏:0      [点我收藏+]

标签:


题目来源


https://leetcode.com/problems/next-permutation/

Implement next permutation, which rearranges numbers into the lexicographically next greater permutation of numbers.

If such arrangement is not possible, it must rearrange it as the lowest possible order (ie, sorted in ascending order).

The replacement must be in-place, do not allocate extra memory.


题意分析


Input:一个数组

Output:一个数组(原地操作)

Conditions:输出数组是输入数组的下一个比输入大的数组。 如[1, 2, 3] => [1, 3, 2]

                 如果输入的是最大的,那么输出最小的数组。    如[3, 2, 1]  => [1, 2, 3]


 题目思路


 

  1. 从后往前找第一个比前面大的数字,若是不存在,则已经是最大的数组,直接原地升序排序(list.sort())返回
  2. 若是找到最大的值,记录其位置index,然后在index之后(包括index)找一个比nums[index - 1]大的最小值,并将其与nums[index - 1]交换
  3. 对index之后(包括index)的nums数组元素进行冒泡排序

 AC代码(Python)


技术分享
 1 _author_ = "YE"
 2 # -*- coding:utf-8 -*-
 3 class Solution(object):
 4     def nextPermutation(self, nums):
 5         """
 6         :type nums: List[int]
 7         :rtype: void Do not return anything, modify nums in-place instead.
 8         """
 9         #print(nums)
10         len1 = len(nums)
11         index = -1
12         for i in range(len1 - 1):
13             if nums[len1 - 1 - i] > nums[len1 - i - 2]:
14                 index = len1 - 1 - i
15                 break
16         if index == -1:
17             nums.sort()
18         else:
19             minindex = index
20             minvalue = nums[index]
21             for i in range(len1 - index - 1):
22                 if  minvalue > nums[index + i + 1] > nums[index - 1]:
23                     minindex = index + i + 1
24                     minvalue = nums[minindex]
25 
26             nums[minindex] = nums[index - 1]
27             nums[index - 1] = minvalue
28 
29             #sort other numbers from index
30             numbers = len1 - index
31             #print(numbers)
32             for i in range(numbers - 1):
33                 print(I:,i)
34                 for j in range(numbers - i - 1):
35                     if nums[len1 - j - 1] < nums[len1 - j - 2]:
36                         temp = nums[len1 - j - 1]
37                         nums[len1 - j - 1] = nums[len1 - j - 2]
38                         nums[len1 - j - 2] = temp
39 
40             #print(minindex, minvalue)
41         #print(nums)
View Code

 

[LeetCode]题解(python):031-Next Permutation

标签:

原文地址:http://www.cnblogs.com/loadofleaf/p/5001619.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!