如果整数 x
满足:对于每个数位 d
,这个数位 恰好 在 x
中出现 d
次。那么整数 x
就是一个 数值平衡数 。
给你一个整数 n
,请你返回 严格大于 n
的 最小数值平衡数 。
示例 1:
输入:n = 1 输出:22 解释: 22 是一个数值平衡数,因为: - 数字 2 出现 2 次 这也是严格大于 1 的最小数值平衡数。
示例 2:
输入:n = 1000 输出:1333 解释: 1333 是一个数值平衡数,因为: - 数字 1 出现 1 次。 - 数字 3 出现 3 次。 这也是严格大于 1000 的最小数值平衡数。 注意,1022 不能作为本输入的答案,因为数字 0 的出现次数超过了 0 。
示例 3:
输入:n = 3000 输出:3133 解释: 3133 是一个数值平衡数,因为: - 数字 1 出现 1 次。 - 数字 3 出现 3 次。 这也是严格大于 3000 的最小数值平衡数。
提示:
0 <= n <= 106
class Solution:
def nextBeautifulNumber(self, n: int) -> int:
def check(num):
counter = [0] * 10
for c in str(num):
counter[int(c)] += 1
for c in str(num):
if counter[int(c)] != int(c):
return False
return True
for i in range(n + 1, 10 ** 7):
if (check(i)):
return i
return -1
class Solution {
public int nextBeautifulNumber(int n) {
for (int i = n + 1; i < 10000000; ++i) {
if (check(i)) {
return i;
}
}
return -1;
}
private boolean check(int num) {
int[] counter = new int[10];
char[] chars = String.valueOf(num).toCharArray();
for (char c : chars) {
++counter[c - '0'];
}
for (char c : chars) {
if (counter[c - '0'] != c - '0') {
return false;
}
}
return true;
}
}
function nextBeautifulNumber(n: number): number {
for (let ans = n + 1; ; ans++) {
if (isValid(ans)) {
return ans;
}
}
};
function isValid(n: number): boolean {
let record = new Array(10).fill(0);
while (n > 0) {
const idx = n % 10;
record[idx]++;
n = Math.floor(n / 10);
}
for (let i = 0; i < 10; i++) {
if (record[i] && record[i] != i) return false;
}
return true;
}
class Solution {
public:
int nextBeautifulNumber(int n) {
for (int i = n + 1; i < 10000000; ++i)
{
if (check(i)) return i;
}
return -1;
}
bool check(int num) {
string s = to_string(num);
vector<int> counter(10);
for (char c : s) ++counter[c - '0'];
for (char c : s)
{
if (counter[c - '0'] != c - '0') return false;
}
return true;
}
};
func nextBeautifulNumber(n int) int {
check := func(num int) bool {
s := strconv.Itoa(num)
counter := make([]int, 10)
for _, c := range s {
counter[int(c-'0')]++
}
for _, c := range s {
if counter[int(c-'0')] != int(c-'0') {
return false
}
}
return true
}
for i := n + 1; i <= 10000000; i++ {
if check(i) {
return i
}
}
return -1
}