私は、書き換え規則の RHS に 1 つの非終端記号のみを含む任意の文法 (例: S -> aaSb | aaSa | aSa) に対して、トップダウン バックトラッキング パーサーを実装するプロジェクトを割り当てられました。
main
これまでのところ、入力文字列の有効性のチェックを処理するために使用される を含む 3 つのメソッドがあります。
私の目標はchar[][]
、文法の配列を使用して、入力文字列の各文字を文法に対してチェックし、true
文字列が文法に含まれているかどうかを返すことです。
public class TDBP {
public static void main(String[] args) {
char[][] g = new char[][]
{ {'a', 'a', 'S', 'b'},
{'a', 'a', 'S', 'a'},
{'a', 'S', 'a'},
{'\0'} };
SP(g);
}
public static void SP(char[][] g) {
Scanner s = new Scanner(System.in);
boolean again = true; int pn = 0;
String test;
while(again) {
System.out.print("Next string? ");
test = s.nextLine();
if(S(pn, test, g))
System.out.println("String is in the language");
else
System.out.println("String is not in the language");
if(s.nextLine() == "\n") again = false;
}
s.close();
}
public static boolean S(int pn, String test, char[][] g) {
char[] c = test.toCharArray();
boolean exists = false;
for(int i = pn; i < g.length; i++) {
for(int j = 0; j < g[i].length; j++) {
if(c[j] == 'S')
S(++pn, test, g);
if(c[j] == g[i][j])
exists = true;
}
}
return exists;
}
}
私のアルゴリズムでpn
は、現在見ている文法のどの生成を追跡し、同じ文法を 2 回スキャンしないようにするための整数です (たとえば、pn
上記の文法の 1 は に対応しaaSa
ます)。また、\0
空の文字列を表しています。
文字列を正しく解析していますか?
ありがとうございました!