Codeforces Round #739 (Div. 3)的其他题解在这
F1. Nearest Beautiful Number (easy version)
题目大意:
一个数各数位出现的数字个数小于k的数被称为美丽的数
给出一个数n
求大于等于n的最小美丽的数
1<=k<=2
思路:
由于F1的k只有1或者2,所以我们可以直接暴力预处理出出现数字个数为1和2的所有情况,然后用set去重
求答案时用一下lower_bound即可
AC代码:
#include<cstdio>
#include<iostream>
#include<cstring>
#include<map>
#include<set>
#include<algorithm>
#define ll long long
using namespace std;
const int maxn = 1e6 + 7;
set<ll > s1, s2;
void pre() {
for (ll i = 0; i <= 9; ++i) {
ll num = 0;
for (ll j = 1; j <= 10; ++j) {
num = num * 10 + i;
s1.insert(num);
s2.insert(num);
}
}
for (ll i = 0; i <= 9; ++i){
for (ll j = i + 1; j <= 9; ++j){
for (int k = 0; k < (1 << 10); ++k){
ll num = 0;
for (int l = 0; l <= 9; ++l){
if ((k >> l) & 1)num = num * 10 + i;
else num = num * 10 + j;
s2.insert(num);
}
}
}
}
}
int main() {
pre();
int T;
scanf("%d", &T);
while (T--) {
ll n;
int k;
scanf("%lld %d", &n, &k);
if (k == 1)printf("%lld\n", *s1.lower_bound(n));
else printf("%lld\n",*s2.lower_bound(n));
}
}