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]];
}
我有一个包含 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]];
}