LeetCode 556. 下一个更大元素 III
生活随笔
收集整理的這篇文章主要介紹了
LeetCode 556. 下一个更大元素 III
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1. 題目
給定一個32位正整數(shù) n,你需要找到最小的32位整數(shù),其與 n 中存在的位數(shù)完全相同,并且其值大于n。如果不存在這樣的32位整數(shù),則返回-1。
示例 1: 輸入: 12 輸出: 21示例 2: 輸入: 21 輸出: -1來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/next-greater-element-iii
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。
2. 解題
- 從后往前找,如果找到后面比前面大的,交換兩個數(shù)位
- 并將被交換的數(shù)位的后面從小到大排序
- 注意最后結(jié)果如果大于INT_MAX,返回-1
- 優(yōu)化下,O(n) 時間復(fù)雜度
總結(jié)
以上是生活随笔為你收集整理的LeetCode 556. 下一个更大元素 III的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode 606. 根据二叉树创
- 下一篇: LeetCode 1405. 最长快乐字