2

我的输入语句是:

拉姆你在哪里

之后我会得到这个解析树:

' 2|TYPE|nx0e-VPadjn-Vnx1 1|RPron|nx-RP-S 0|NOUN|NXN 3|NOUN|NXN ', '1'

我想将 2 替换为 'are' 1 与 'where' 并 ram 替换为 0 。

我应该如何使用哈希映射来做到这一点?

4

1 回答 1

1

这个答案基于很多假设,因为您的问题不够清楚。但我没有足够的代表发表评论。

如果您在输入句子上使用String.split()为:

String[] words = "ram where are you".split(" ");
// words[0] => ram
// words[1] => where
// words[2] => are
// words[3] => you

看来您的解析树是通过解析输入句子生成的。
解析树第一部分中的每个条目对应于输入句子中的一个单词。
解析条目中的第一个数字似乎对应于输入句子中每个单词的索引。

所以一个解析条目可以被分解为:<word index>|<word category>|<something not clear>

所以它看起来

2|TYPE|nx0e-VPadjn-Vnx1 => are
1|RPron|nx-RP-S => where
0|NOUN|NXN => ram
3|NOUN|NXN => you

基于这些假设,可以使用使用解析树条目构建的哈希图。
您需要使用 将解析条目放入地图中key = <word index>; value = <parse entry>
这可以通过将解析树分离为条目然后<word index>从每个条目中检索来完成。

构建该映射后,您可以处理输入句子并将树条目解析为:

String[] words = "ram where are you".split(" ");

Map<Integer, String> entriesMap = getEntriesMap(parseTree); // assuming parseTree is just a String

for(int i = 0; i < words.length; i++) {
    String x = entriesMap.get(i).replaceAll("^" + i + "|", words[i]);
}

填充地图的方法。有多种方法可以做到这一点。
使用带有适当正则表达式的PatternMatcher类可能是最好的方法。

private Map<Integer, String> getEntriesMap(String parseTree) {
    Map<Integer, String> entriesMap = new LinkedHashMap<Integer, String>();

    // assuming parseTree format as: '<parse entries separated by spaces>', '1'
    // use String.split() to split the parseTree by single quote (')
    // first element in returning array would contain the <parse entries separated by spaces>
    // use String.split() again on that element with space to separate parse entries
    // for each <entry> in <parse entries>
    //     split <entry> with pipe (|) and use first element in resulting array as the key and <entry> as the value to put in entriesMap

    return entriesMap;
}

无法弄清楚,'1'解析树末尾对应的是什么。

于 2013-04-25T13:18:08.023 回答