具有多个条件的Java三元运算符

时间:2019-09-18 10:44:39

标签: java multidimensional-array conditional-statements ternary-operator

我对Java数据结构还很陌生,我需要一些帮助来使用三元运算符来处理多个条件,或者是否有更好的方法来解决我的工作。

基本上,我有一个文本文件,该文件放入2D数组中,并逐个字符地分隔每个行。

但是,我在使用条件语句检查行中的特定字符时遇到了麻烦。

这是我目前的算法。

for (int i = 2; i < lines.size() - 1; i++) {
        String floorLine = lines.get(i);
        int j = 0;
        for(char coor : floorLine.toCharArray()) {
              floor[i - 2][j] = (coor == '#') ? 0 : 1;
        }
    }

截至目前,我仅检查是否有行,然后将其编码为 0 ,否则为 1 。但是,我想要这样的东西

floor[i-2][j] = (coor == '#') ? 0 floor[i-2][j] = (coor == 'X') ? 1 floor[i-2][j] = (coor == 'Z') ? 2 : 3

因此,如果我使用普通的if else语句,我应该像这样

if 2d array == ( coor == '#') encode as 0
if 2d array == ( coor == 'X') encode as 1
if 2d array == ( coor == 'Z') encode as 2
else encode as 3

任何建议或提示将不胜感激!预先谢谢你。

4 个答案:

答案 0 :(得分:2)

也可以提出我的写法。将条件插入新方法中。

floor[i - 2][j] = getNumberForCoor(coor);



private static int getNumberForCoor(char coor) {
    switch (coor) {
        case '#': return 0;
        case 'X': return 1;
        case 'Z': return 2;
        default:  return 3;
    }
}

答案 1 :(得分:1)

条件表达式的形式为:

condition? value_if_true : value_if_false

链接起来后,看起来像这样:

condition_1 ? value_if_1 : condition_2 ? value_if_2 : value_otherwise

所以我想你的意思是

floor[i-2][j] = (coor=='#' ? 0 : coor=='X' ? 1 : coor=='Z' ? 2 : 3);

对我来说,这很简单,可以完全理解,但是很多人反对这种条件运算符的使用。并且如果更复杂的话,最好改用if语句。

Java正在引入switch expressions,在这种情况下也可以很好地工作。

答案 2 :(得分:0)

除了三元表达链外,我还有两种选择:

  • 从char到int的预先计算的映射。
  • 如果结果是连续编号0、1、2,...,则字符串中char的索引可用。

所以

Map<Character, Integer> map = new HashMap<>();
map.put('#', 0);
map.put('X', 1);
map.put('!', 2);

String enc = "#X!";

for (int i = 2; i < lines.size() - 1; i++) {
    String floorLine = lines.get(i);
    int j = 0;
    for(char coor : floorLine.toCharArray()) {
          floor[i - 2][j] = coor == '#' ? 0
                 : coor == 'X' ? 1
                 : coor == '!' ? 2
                 : 3;

          floor[i - 2][j] = map.getOrDefault(coor, 3);

          int e = enc.indexOf(coor);
          floor[i - 2][j] = e == -1 ? 3 : e;
    }
}

答案 3 :(得分:0)

看起来您可以将替换项放在地图中。

static Map<Character, Integer> encodings = new HashMap<>();

static {
    // static initializer, a way to populate the map easily, not the only way
    encodings.put('#', 0);
    encodings.put('X', 1);
    encodings.put('Z', 2);
}

//and in your function
floor[i-2][j] = encodings.getOrDefault(coor, 3);