【问题标题】:telephone number to character converter电话号码转字符转换器
【发布时间】:2017-05-07 04:37:20
【问题描述】:

我是 Java 新手,我有一个家庭作业,我应该在其中编写一个程序,将电话号码转换为与该号码关联的所有可能的字符串。不过,我很难弄清楚这一点的逻辑。这就是我到目前为止所拥有的。任何建议,将不胜感激。

import java.util.*;
public class phoneNumberString{
String[] thisString = {""};
public static void main(String[] args) {


}  
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) {

for(int i = 0; i < dialPad.length; i++)

    if(i == 0 ||  i == 1 )
        thisString = new String [] {""};

return thisString;

        }

public static void print(String[] thisString) {
    System.out.println(thisString);
}

}

【问题讨论】:

  • 在这种情况下,我发现选择一个小例子并在远离计算机的情况下手工完成是很有用的......看看你的大脑如何解决它,你采取了哪些步骤......然后将其转化为算法......
  • 谢谢。我早上再看看。感谢您完成这些步骤的方式。

标签: java arrays string for-loop


【解决方案1】:

所以首先要做的就是将数字分解成相应的数字......即 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]

【讨论】:

  • 我还有几个问题:如果我想随机化拨打的号码以查看所有可能的组合,以及如何使用 PrintStream 将其打印到文件中?
猜你喜欢
  • 2017-04-20
  • 2014-06-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多