文章作者:Tyan
博客:noahsnail.com | CSDN | 简书
1. Description
2. Solution
解析:Version 1,先将数字n
变为字符数组,要找最小的大于n
的数,则应该从右往左开始,依次寻找第i
位字符右边的大于当前字符的最小数字,然后互换二者位置,由于新数字的第i
位字符大于n
中的第i
位字符,因此新数字i
位之后的字符应该从小到大排列,这样可以保证新数字是最小的大于n
的数字。当每一个字符都大于其右边的字符时,则找不到大于n
的数字,返回-1
。如果新数字大于2^31-1
,也应该返回-1
。Version 2,先找可以跟右边数字互换的字符digits[i]
,即右边存在大于它的字符。连续比较两个相邻字符,保证了digits[i]
右边的字符从大到小的关系。找到之后,再从右边寻找大于digits[i]
的最小字符digits[j]
,由于右边字符从大到小的关系,因此只要字符digits[j]
大于digits[i]
,digits[j]
就是大于digits[i]
的最小字符。
- Version 1
1 | class Solution: |
- Version 2
1 | class Solution: |