Next Greater Numerically Balanced Number
Problem Statement - link #
An integer x is numerically balanced if for every digit d in the number x, there are exactly d occurrences of that digit in x.
Given an integer n, return the smallest numerically balanced number strictly greater than n.
Examples #
Example 1:
Input: n = 1
Output: 22
Explanation: 
22 is numerically balanced since:
- The digit 2 occurs 2 times. 
It is also the smallest numerically balanced number strictly greater than 1.
Example 2:
Input: n = 1000
Output: 1333
Explanation: 
1333 is numerically balanced since:
- The digit 1 occurs 1 time.
- The digit 3 occurs 3 times. 
It is also the smallest numerically balanced number strictly greater than 1000.
Note that 1022 cannot be the answer because 0 appeared more than 0 times.
Example 3:
Input: n = 3000
Output: 3133
Explanation: 
3133 is numerically balanced since:
- The digit 1 occurs 1 time.
- The digit 3 occurs 3 times.
It is also the smallest numerically balanced number strictly greater than 3000.
Constraints #
- 0 <= n <= 10^6
Solutions #
class Solution {
public:
    bool bt(int n){
        int d[10]={},x=n;
        while(x){d[x%10]++;x/=10;}
        for(int i=0;i<10;i++){if(d[i] and d[i]!=i) return false;}
        return true;
    }
    int nextBeautifulNumber(int n) {
        for(n++;!bt(n);n++);
        return n;
    }
};