LeetCode556. Next Greater Element III

LeetCode556. Next Greater Element III

题目:Given a positive 32-bit integer n, you need to find the smallest 32-bit integer which has exactly the same digits existing in the integern and is greater in value than n. If no such positive 32-bit integer exists, you need to return -1.

Example 1:

Input: 12
Output: 21

Example 2:

Input: 21
Output: -1

题意分析:这道题和其实和31. Next Permutation差不多,都是考的同样的考点,所以也没啥特别的分析,有兴趣的话可以去看下31题的leetcode。

代码:
class Solution {
public:
	int nextGreaterElement(int n) {
		string str = to_string(n);
		string tmp = str;
		next_permutation(str.begin(),str.end());
		if (tmp >= str) {
			return -1;
		}
		else {
			return stringtoint(str);
		}
	}
	int stringtoint(string str) {
		int size = str.size() - 1,sum = 0;
		for (int i = 0; i < str.size(); i++) {
			sum += pow(10, size--)*(str[i] - '0');
			if (sum < 0) return -1;
		}
		return sum;
	}
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值