g0901_1000.s0967_numbers_with_same_consecutive_differences.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g0901_1000.s0967_numbers_with_same_consecutive_differences;
// #Medium #Breadth_First_Search #Backtracking
import java.util.ArrayList;
import java.util.List;
public class Solution {
public int[] numsSameConsecDiff(int n, int k) {
k = Math.abs(k);
List list = new ArrayList<>();
dfs(list, 100000, 0, n, k);
int[] res = new int[list.size()];
for (int i = 0; i < res.length; i++) {
res[i] = list.get(i);
}
return res;
}
private void dfs(List list, int can, int len, int n, int k) {
if (len == n) {
list.add(can);
return;
}
if (can == 0) {
return;
}
if (len == 0) {
for (int i = 0; i <= 9; i++) {
dfs(list, i, 1, n, k);
}
} else {
int last = can % 10;
int a = last + k;
int b = last - k;
if (b >= 0) {
dfs(list, can * 10 + b, len + 1, n, k);
}
if (k != 0 && a < 10) {
dfs(list, can * 10 + a, len + 1, n, k);
}
}
}
}