js switch语句遵循一种模式

js switch statement follows a pattern

我有一个包含 33 个案例的 switch 语句,每个案例对应于二维数组中的一列。数组中的值也是将被转换的行。有没有更简洁的方法来写这个?每个案例都遵循模式 for letter in alphabet dfarow = [dfarow][n+1]

function FEN2datumType(fen, dfa) {    

//                 alpabet length 33                            
// exampleDFA = [[1, 0, 1, 2, 1, 0, 1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 2, 1, 0, 1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 0]], 
//              [[1, 1, 2, 2, 1, 0, 1, 2, 1, 1, 2, 2, 1, 1, 1, 1, 1, 0, 1, 2, 1, 0, 1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 0]],
//              [[2, 1, 2, 2, 1, 0, 1, 2, 2, 1, 1, 2, 2, 1, 1, 1, 2, 1, 0, 1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0, 2, 2]]

dfarow = 0; // start state
for (char in fen) { 
  switch (char) {
    case "r":      //alpabet 0
      dfarow = dfa[dfarow][0];
      break;
    case "n":
      dfarow = dfa[dfarow][1];
      break;
    case "b":
      dfarow = dfa[dfarow][2];
      break;
    case "q":
      dfarow = dfa[dfarow][3];
      break;
    case "k":
      dfarow = dfa[dfarow][4];
      break;
    case "p":
      dfarow = dfa[dfarow][5];
      break;
.....etc...

这是我写的第一个DFA,我愿意接受建议。 我的字母表是 FEN 字符串(Forsyth–Edwards Notation chess)33 个可能的字符。 exampleDFA 有 3 个过渡状态,我还没有实现接受状态(我正在考虑将标识符放在 DFA 数组的第 34 列,即 if (dfa[dfarow][34] == 1) //accept

您可以为字母表创建对象:

var alphabet = { r:0, n:1, b:2, .... }

然后你可以在for循环中调用alphabet对象:

for (char in fen) { 
  dfarow = dfa[dfarow][alphabet[char]];
}