leetcode 556. 下一个更大元素 III

Posted 巴蜀小小生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode 556. 下一个更大元素 III相关的知识,希望对你有一定的参考价值。

给定一个32位正整数 n,你需要找到最小的32位整数,其与 n 中存在的位数完全相同,并且其值大于n。如果不存在这样的32位整数,则返回-1。

示例 1:

输入: 12
输出: 21

示例 2:

输入: 21
输出: -1

个人感觉这一题比ii还要简单一些
思路:从地位开始找到数字比前一位数字小的位置,这个位置就是要替换的
和哪一个位置的数字交换呢?和大于且最接近它的位置的数字交换,这样能保证其值比原来大,且最接近
 1 #include<iostream>
 2 class Solution {
 3 public:
 4     static bool cmp(int a, int b){return a > b;}
 5     int nextGreaterElement(int n) {
 6         vector<int> digit;
 7         int temp = 0, t = n;
 8         while(n){
 9             digit.push_back(n%10);
10             n /= 10;
11         }
12         int len = digit.size(), i;
13         for(i = 1; i < len; i++){//找到要交换的位置
14             if(digit[i] < digit[i-1])
15                 break;
16         }
17         sort(digit.begin(), digit.begin()+i, cmp);
18         for(int k = i-1; k >= 0; k--){
19             if(digit[k] > digit[i]){//找到与其交换的位置
20                 swap(digit[k], digit[i]);
21                 break;
22             }
23         }
24         for(int j = len-1; j >= 0; j--) temp = temp*10 + digit[j];
25         temp = (temp>t) ? temp : -1;
26         return temp;
27     }
28 };

 

以上是关于leetcode 556. 下一个更大元素 III的主要内容,如果未能解决你的问题,请参考以下文章

leetcode 556. 下一个更大元素 III

556. 下一个更大元素 III

每日一题556. 下一个更大元素 III

LeetCode 0556.下一个更大元素 III - 4步讲完

[LeetCode] 556. Next Greater Element III

字符串556. 下一个更大元素 III