comments | difficulty | edit_url | tags | ||
---|---|---|---|---|---|
true |
中等 |
|
给你三个整数, k
, digit1
和 digit2
, 你想要找到满足以下条件的 最小 整数:
- 大于
k
且是k
的倍数 - 仅由
digit1
和digit2
组成,即 每一位数 均是digit1
或digit2
请你返回 最小的满足这两个条件的整数,如果不存在这样的整数,或者最小的满足这两个条件的整数不在32位整数范围(0~231-1
),就返回 -1
。
示例 1:
输入:k = 2, digit1 = 0, digit2 = 2 输出:20 解释: 20 是第一个仅有数字0和2组成的,比2大且是2的倍数的整数。
示例 2:
输入:k = 3, digit1 = 4, digit2 = 2 输出:24 解释: 24 是第一个仅有数字 2 和 4 组成的,比 3 大且是 3 的倍数的整数。
示例 3:
输入:k = 2, digit1 = 0, digit2 = 0 输出:-1 解释: 不存在仅由 0 组成的比 2 大且是 2 的倍数的整数,因此返回 -1 。
提示:
1 <= k <= 1000
0 <= digit1 <= 9
0 <= digit2 <= 9
我们观察
否则,我们不妨设
时间复杂度
class Solution:
def findInteger(self, k: int, digit1: int, digit2: int) -> int:
if digit1 == 0 and digit2 == 0:
return -1
if digit1 > digit2:
return self.findInteger(k, digit2, digit1)
q = deque([0])
while 1:
x = q.popleft()
if x > 2**31 - 1:
return -1
if x > k and x % k == 0:
return x
q.append(x * 10 + digit1)
if digit1 != digit2:
q.append(x * 10 + digit2)
class Solution {
public int findInteger(int k, int digit1, int digit2) {
if (digit1 == 0 && digit2 == 0) {
return -1;
}
if (digit1 > digit2) {
return findInteger(k, digit2, digit1);
}
Deque<Long> q = new ArrayDeque<>();
q.offer(0L);
while (true) {
long x = q.poll();
if (x > Integer.MAX_VALUE) {
return -1;
}
if (x > k && x % k == 0) {
return (int) x;
}
q.offer(x * 10 + digit1);
if (digit1 != digit2) {
q.offer(x * 10 + digit2);
}
}
}
}
class Solution {
public:
int findInteger(int k, int digit1, int digit2) {
if (digit1 == 0 && digit2 == 0) {
return -1;
}
if (digit1 > digit2) {
swap(digit1, digit2);
}
queue<long long> q{{0}};
while (1) {
long long x = q.front();
q.pop();
if (x > INT_MAX) {
return -1;
}
if (x > k && x % k == 0) {
return x;
}
q.emplace(x * 10 + digit1);
if (digit1 != digit2) {
q.emplace(x * 10 + digit2);
}
}
}
};
func findInteger(k int, digit1 int, digit2 int) int {
if digit1 == 0 && digit2 == 0 {
return -1
}
if digit1 > digit2 {
digit1, digit2 = digit2, digit1
}
q := []int{0}
for {
x := q[0]
q = q[1:]
if x > math.MaxInt32 {
return -1
}
if x > k && x%k == 0 {
return x
}
q = append(q, x*10+digit1)
if digit1 != digit2 {
q = append(q, x*10+digit2)
}
}
}