2 回答
![?](http://img1.sycdn.imooc.com/54584f9d0001219b02200220-100-100.jpg)
TA贡献1804条经验 获得超8个赞
基于Nina Scholz 的想法:
public static void main(String[] args) {
String example= " _ _ _ _ _ _ _ _ \n| | | _| _||_||_ |_ ||_||_| \n|_| ||_ _| | _||_| ||_| _|";
System.out.println(get7segment(example));
}
private static String get7segment(String ascii) {
String result = "";
String[] lines = ascii.split("\n");
String[] line1;
String[] line2;
String[] line3;
for (int j = 0; j < lines.length - 2; j += 4) {
line1 = lines[j].split("");
line2 = lines[j + 1].split("");
line3 = lines[j + 2].split("");
String pow = "";
int mod = 3;
for (int i = 0; i < line1.length; i++) {
if (i % mod == 0) {
String strAs = digitToString(pow);
result += strAs;
pow = "";
}
if (line1[i].equals("_") && i % mod == 1)
pow += "0";
if (line2[i].equals("|") && i % mod == 0)// left
pow += "5";
if (line2[i].equals("|") && i % mod == 2)// right
pow += "1";
if (line2[i].equals("_") && i % mod == 1)// bottom
pow += "6";
if (line3[i].equals("|") && i % mod == 0)// left
pow += "4";
if (line3[i].equals("|") && i % mod == 2)// right
pow += "2";
if (line3[i].equals("_") && i % mod == 1)// bottom
pow += "3";
if (line1.length - 1 == i) {
String strAs = digitToString(pow);
result += strAs;
pow = "";
}
}
result += "\n";
}
return result;
}
/*
* Converting single ascii digit to regular digit
*/
private static String digitToString(String asciiDigit) {
if (asciiDigit == null || asciiDigit.equals(""))
return "";
int pow = 0;
for (int i = 0; i < asciiDigit.length(); i++)
pow += Math.pow(2, Character.getNumericValue(asciiDigit.charAt(i)));
HashMap<Integer, Integer> map = new HashMap<Integer, Integer>() {
{
put(63, 0);
put(6, 1);
put(91, 2);
put(79, 3);
put(102, 4);
put(109, 5);
put(125, 6);
put(7, 7);
put(127, 8);
put(111, 9);
}
};
return map.containsKey(pow) ? Integer.toString(map.get(pow)) : "?";
}
输出:
0123456789
![?](http://img1.sycdn.imooc.com/53339fdf00019de902200220-100-100.jpg)
TA贡献1853条经验 获得超9个赞
尝试将三行字符串解析为数字序列将很棘手,因为在数字之间没有某种分隔符。
123456789012345678901234567890
..._.._....._.._.._.._.._.._..
.|._|._||_||_.|_...||_||_||.|.
.||_.._|..|._||_|..||_|._||_|.
123456789012345678901234567890
上面是您的原始示例,其中的空格被点替换以突出显示它们。请注意,有些数字是 1 个字符宽 ('1'),有些是 2 个字符 ('3', '7'),其余的则是 3 个字符。
问题: - '1's 总是只占两列吗?- '2' 和 '3' 之间以及 '6' 和 '7' 之间有一个空格,但其他数字之间没有。在“1”之前还有一个前导空格。需要少于三列的字符是否会有前导空格的规则?- 还会有其他空间吗?
我这样做的方法是制作一个带有三个字符串(三行)的对象。字符串必须等长。然后,实现一个 char-wise 解析器,将字符从三个字符串中平均提取出来。如果所有三个字符都是空格,请删除它们。如果没有,读一栏,你有'1'吗?如果没有,请阅读另一个,你有“3”还是“7”?如果没有,请阅读第三篇,你有什么性格?
这有帮助吗?
添加回答
举报