赞
踩
【任务3 - 特征提取】
正向最大(Maximum Matching, MM):
算法思想:
从左到右将待分词文本中的几个连续字符与词表匹配,如果匹配上,则切分出一个词。但这里有一个问题:要做到最大匹配,并不是第一次匹配到就可以切分的 。我们来举个例子:
待分词文本: content[]={“中”,“华”,“民”,“族”,“从”,“此”,“站”,“起”,“来”,“了”,"。"}
词表: dict[]={“中华”, “中华民族” , “从此”,“站起来”}
(1) 从content[1]开始,当扫描到content[2]的时候,发现"中华"已经在词表dict[]中了。但还不能切分出来,因为我们不知道后面的词语能不能组成更长的词(最大匹配)。
(2) 继续扫描content[3],发现"中华民"并不是dict[]中的词。但是我们还不能确定是否前面找到的"中华"已经是最大的词了。因为"中华民"是dict[2]的前缀。
(3) 扫描content[4],发现"中华民族"是dict[]中的词。继续扫描下去:
(4) 当扫描content[5]的时候,发现"中华民族从"并不是词表中的词,也不是词的前缀。因此可以切分出前面最大的词——“中华民族”。
由此可见,最大匹配出的词必须保证下一个扫描不是词表中的词或词的前缀才可以结束。
sudo-code
result = []
right_seq = input_seq
while True:
select_seq,left_seq = get_select_seq(right_seq)
seg_word,seg_word_right = selectMaxLenInDict(select_seq)
result.append(seg_seq)
right_seq = seg_word_right+left_seq
if right_seq=="":
break
def selectMaxLenInDict(_seq):
for idx in range(len(select_seq),1
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。