所以首先要做的就是将数字分解成相应的数字......即 1234 是 1、2、3.... 各种解决方案,但没有数学最容易理解的是通过字符串操作。
private int[] numberAsDigits(int number) {
String numberAsString = String.valueOf(number);
int[] numberAsDigits = new int[numberAsString.length()];
char[] chars = numberAsString.toCharArray();
for (int i = 0; i < chars.length; i++) {
numberAsDigits[i] = Integer.parseInt(String.valueOf(chars[i]));
}
return numberAsDigits;
}
现在您需要对所有组合进行交互...假设数字是“223”...您的第一个组合将是 AAD,然后是 BAD,然后是 CAD,等等。当您到达 CAD 时,您的下一个组合将是是 ABD。为了保持您的位置,您需要一个与数字长度相同的“计数器”数组。
int[] counters = new int[numberAsDigits.length];
所以你从计数器构建你的字符串
// current combination
StringBuilder builder = new StringBuilder();
for (int i = 0; i < counters.length; i++) {
String[] combosForCurrentDigit= dialPad[numberAsDigits[i]];
builder.append(combosForCurrentDigit[counters[i]]);
}
results.add(builder.toString());
下一位是将计数器递增到下一个组合。首先添加到第一个,然后“涟漪”或“延续”更新,当它们到达末尾时,重置并增加下一个,即与从 99 到 100 时计数的逻辑相同。请注意,我们还需要包含一个结束条件,这是最后一个计数器超过数组末尾的时间。
// increment the counters
counters[0]++;
for (int i = 0; i < counters.length; i++) {
String[] combosForCurrentDigit = dialPad[numberAsDigits[i]];
if (counters[i] == combosForCurrentDigit.length) {
counters[i] = 0;
if (i + 1 == counters.length) {
finished = true;
} else {
counters[i + 1]++;
}
}
}
把它们放在一起
public static void main(String[] args) {
System.out.println(Arrays.toString(new phoneNumberString().dial(223)));
}
public static String dialPad[][] = { { "0" }, { "1" }, { "A", "B", "C" }, { "D", "E", "F" }, { "G", "H", "I" },
{ "J", "K", "L" }, { "M", "N", "O" }, { "P", "Q", "R", "S" }, { "T", "U", "V" }, { "W", "X", "Y", "Z" } };
public String[] dial(int number) {
int[] numberAsDigits = numberAsDigits(number);
int[] counters = new int[numberAsDigits.length];
boolean finished = false;
List<String> results = new ArrayList<>();
while (!finished) {
// current combination
StringBuilder builder = new StringBuilder();
for (int i = 0; i < counters.length; i++) {
String[] combosForCurrentDigit = dialPad[numberAsDigits[i]];
builder.append(combosForCurrentDigit[counters[i]]);
}
results.add(builder.toString());
// increment the counters
counters[0]++;
for (int i = 0; i < counters.length; i++) {
String[] combosForCurrentDigit = dialPad[numberAsDigits[i]];
if (counters[i] == combosForCurrentDigit.length) {
counters[i] = 0;
if (i + 1 == counters.length) {
finished = true;
} else {
counters[i + 1]++;
}
}
}
}
return results.toArray(new String[0]);
}
private int[] numberAsDigits(int number) {
String numberAsString = String.valueOf(number);
int[] numberAsDigits = new int[numberAsString.length()];
char[] chars = numberAsString.toCharArray();
for (int i = 0; i < chars.length; i++) {
numberAsDigits[i] = Integer.parseInt(String.valueOf(chars[i]));
}
return numberAsDigits;
}
输出
[AAD, BAD, CAD, ABD, BBD, CBD, ACD, BCD, CCD, AAE, BAE, CAE, ABE, BBE, CBE, ACE, BCE, CCE, AAF, BAF, CAF, ABF, BBF, CBF, ACF, BCF, CCF]