首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自然语言解析

自然语言解析
EN

Stack Overflow用户
提问于 2017-08-09 09:07:40
回答 1查看 98关注 0票数 2

分析自然语言最有效的方法是什么?

将“字符串”设为包含字符串的map<string, void (*func)(int,char**)>,如:

代码语言:javascript
复制
Set the alarm for *.
Call *.
Get me an * at * for *.

以及相应的功能。现在,假设"input“是一个包含如下句子的string

代码语言:javascript
复制
Call David.

如何实现像parse这样的函数,它将接受“输入”并将其匹配到映射中的一个字符串。然后调用它的相应函数,传递给它argc和argv,其中包含所有的通配符(*在字符串中)。实现这种功能最有效的方法是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-09 09:32:44

不知道为什么这个问题被否决了。它摆得很好,不平凡。

解析有很多的学术方法,这些都是退化语法所需要的。“自然语言”可能不是一个定义明确的术语,自然语言确实有一些歧义,但这种受限子集并不是问题。

在这个具体的例子中,我们看到不同的生产规则(映射条目)并不是相互模糊的。事实上,第一个标记足以消除歧义。由于对std::map进行了排序,我们可以对该令牌进行有效的O(log )搜索。

因此,我们只需要导出替换。再一次,我们会忽略那些退化的案例。“没有人会为"Get me an at at at for at烦恼。”“,尽管它明确地进行了分析。

相反,对于替换,您只需收集令牌,直到得到预期的下一个令牌。Get me an * at * for *.意味着第一个*将所有令牌都收集到at,第二个*收集令牌到for,最后一个*获取所有剩余的令牌。

你知道不需要回溯。如果解析失败,根本就没有匹配。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45586245

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档