有很多named graph types。我想知道这个分类背后的标准是什么。不同的类型适用于不同的环境吗?而且,从商业应用程序(从设计和编程的角度来看)是否可以从这些分类中获益?这类似于设计模式吗?各种图形类型的意义
回答
我们给名图的普通家庭有以下几个原因:
图的某些家庭拥有不错的,简单的属性。例如,trees具有许多有用的属性(任何一对节点之间只有一条路径,它们最大程度地是非循环的,它们最小连接等),不包含任意图。 Directed acyclic graphs可以是topologically sorted,正常图不能。如果您可以使用这些类型的图表之一对问题进行建模,则可以使用它们上的专用算法来提取不一定能从任意图表获得的属性。
某些算法在某些类型的图表上运行得更快。许多图上的NP难问题,到目前为止还没有任何多项式时间算法,可以很容易地在某些类型的图上求解。例如,maximum independent set problem(选择没有两个节点通过边连接的节点的最大集合)是NP-hard,但可以在树和bipartite graphs的多项式时间内求解。 4着色问题(确定一个图的节点是否可以用四种不同颜色中的一种着色,而不向相邻节点分配相同的颜色)通常是NP-hard,但对于planar graphs(这是着名的四 - 色原理)。
某些算法在某些类型的图上更容易。图中的matching是图中没有两个边共享端点的边的集合。可以使用最大匹配来表示将人员组合成组的方式。在二分图中,可以使用最大匹配来表示将人员分配给任务的方式,使得没有人被分配两个任务并且没有任务被分配给两个人。有许多快速算法用于在双向图中找到最大匹配,该算法工作迅速且易于理解。一般图的相应算法明显更复杂,效率略低。
某些图表具有历史意义。许多命名图是以某人使用该图来反驳关于任意图的属性的猜测的名字命名的。例如,Petersen graph是许多定理的反例,对于图似乎是正确的,但事实上并非如此。
某些图表在理论计算机科学中很有用。一个expander graph是一个图,直观地说,任何节点集合都必须连接到图中比例较大的节点集合。并非所有图都是扩展图。 Expander图用于理论计算机科学中的许多结果,例如PCP定理的一个证明和证明SL = L。
这不是我们为什么关心不同的图科一个详尽的清单,但希望它有助于激发他们的使用和研究。
希望这会有所帮助!
- 1. 各种类型的集合
- 2. 各种数据类型
- 3. 从各种文档类型
- 4. 在各种缓存中有意义
- 5. 在线编辑器为各种文件类型,文档,图形,图像
- 6. 存储各种类型的载体
- 7. C#各种类型的循环使用
- 8. Java ArrayList与各种类型的对象
- 9. 各种类型的编译器优化?
- 10. VBA:为各种形式的
- 11. 如何确定包含各种形状的工作表上的形状类型?
- 12. 如何动态绘制各种图形
- 13. 各种活动,各种意图,失败的名称应用程序
- 14. 什么是.NET的各种文件类型的mime类型?
- 15. 让骆驼处理各种URI类型
- 16. 介绍各种攻击类型
- 17. 各种数据类型订货代表
- 18. 跨各种模块管理用户定义类型
- 19. 栏目视图按各种分类排序模型
- 20. 各种标签对github中的问题有何意义?
- 21. Java泛型 - 命名实际的各种实际类型的
- 22. 如何在C++中将各种类型存储为一种类型?
- 23. 各种形式的函数getline()的
- 24. 泛型列表或各种类型的字典
- 25. 各种视图模型结构 - 如何创建视图模型
- 26. 指向类族内各种类型指针的限制?
- 27. 正常化具有类似数据类型的各种属性
- 28. 这种类型的宏有什么意义?
- 29. 图形类型;图形的类型层次结构(JUNG,JUNG2)
- 30. 如何在Puppet中组织各种模块中的自定义类型
嗯。地球上可能有万亿棵树。其中一些被命名,大部分不是。为什么?这是相同的原因。一些图表在历史上和科学上都很重要,这就是为什么他们有“名字”。 – ElKamina 2013-05-02 16:40:01
共享词汇? – Pramod 2013-05-02 16:40:04
对于程序员来说,答案可能会非常不同于数学家。这可能是错误的地方,取决于上下文,但我不能成为唯一的希望从这个问题中学到东西的人! :) – corsiKa 2013-05-02 16:40:15