jjzjj

graph-algorithm

全部标签

c++ - 返回 Boost Graph 中连接的组件子图的列表

我在过滤原始图中具有相同组件的子图时遇到问题。我想将它们输出到子图的vector中。按照`connected_components中的示例,我尝试使其适应我的需要://CreateatypedeffortheGraphtypetypedefadjacency_list,property>Graph;//typedefsubgraphSubGraph;typedeftypenamegraph_traits::vertex_descriptorVertex;typedeftypenamegraph_traits::edge_descriptorEdge;typedefgraph_trait

Unifying Large Language Models and Knowledge Graphs: A Roadmap 论文阅读笔记

KeyWords: NLP,LLM,GenerativePre-training,KGs,Roadmap,BidirectionalReasoningAbstract:LLMsareblackmodelsandcan'tcaptureandaccessfactualknowledge.KGsarestructuredknowledgemodelsthatexplicitlystorerichfactualknowledge.ThecombinationsofKGsandLLMshavethreeframeworks, KG-enhancedLLMs,pre-trainingandinferen

c++ - STL - 在 <algorithm> 中使用成员函数或函数?

我想到这个问题是因为我得到了以下问题的一些答案,表明我可以使用vector::assign或copy用back_insert_iteratorhere.我的问题是,使用一种方法相对于另一种方法的优缺点是什么? 最佳答案 assign覆盖vector的内容,其中copywithback_insert_iterator执行push_back在vector上,从而保留其内容。编辑:如果问题是通用的(即是使用容器中定义的成员函数还是算法),我更喜欢使用成员函数,因为它可能已针对特定问题进行了优化与通用算法相比的容器。

c++ - 如何使用 Boost Graph Library 更改图中的边权重?

我已经使用Boost图形库定义了一个图形,typedefboost::propertyEdgeWeightProperty;typedefboost::adjacency_listGraph;使用添加边相当简单boost::add_edge(vertice1,vertice2,weight,graph);我还没有弄清楚如何在设置边缘权重后更改它。一种可能的解决方案是删除边缘并使用更新后的权重值重新添加它,但是,这似乎有点过分。 最佳答案 一种解决方案是执行以下操作typedefboost::adjacency_listGraph;t

algorithm - 3D 中点 A 是否靠近点 B - 距离检查

我正在寻找一种有效的算法来检查一个点是否在3D中的另一个点附近。sqrt((x2-x1)^2+(y2-y1)^2+(z2-z1)^2)这似乎并不太快,实际上我不需要这么大的精度。我还能怎么做? 最佳答案 对距离求平方,并放弃对sqrt()的调用,这样会快得多:(((x2-x1)^2+(y2-y1)^2+(z2-z1)^2当然,在许多情况下,至少可以提前计算出radius*radius并存储为例如squaredRadius。 关于algorithm-3D中点A是否靠近点B-距离检查,我们在

Microsoft Graph-已删除的项目文件夹删除事件

我希望返回已删除项目文件夹中的所有日历事件。目前,我正在使用该通话:https://graph.microsoft.com/beta/me/mailFolders/{deletedItems-id}/messages但这仅返回已删除的消息。有没有可用的电话可以使我检索已删除的事件?提前致谢。看答案一个想法是查询所有事件,并在isCancelled属性,可选添加startDateTime和enddatetime限制搜索。GEThttps://graph.microsoft.com/v1.0/me/events?$filter=isCancelledeqtrue另外,我还测试了查询已删除消息文件夹

c++ - 在真实 3D 环境(例如建筑物)中寻路

是否有一种寻路算法也适用于真实的3D环境,例如具有多个楼梯等的真实建筑物。C++库或开放式实现会很棒;-)我看到的一种解决方案是Djikstra,但我想知道是否有更优化的解决方案。普通A*不会比Djikstra更好,因为距离启发式算法效果不佳(位于目的地上方一层)。我目前正在考虑的另一个解决方案是将3d环境映射到2d图上。因此,如果有一些可用的C++实现/库以这种方式进行,它也会有所帮助。 最佳答案 如果路径必须考虑穿越障碍物的能力(即运动是空间中已知体积的某个实体的运动),那么我建议查看有关机器人运动规划的文献。配置空间的概念允许

c++ - Boost Graph Library astar和导航网格

我在做一个项目SFML/C++,我需要生成一个图来连接它们之间的障碍物以方便寻路,所以我有兴趣生成一个导航网格,我将应用boostA*算法。有点像这样:但是我在使用BoostGraphLibrary实现它时遇到了很多问题(如果您有一个更合适的库,我很感兴趣)。首先,我创建一个具有适当结构的adjacency_list:structWayPoint{sf::Vector2fpos;};structWayPointConnection{floatdist;};typedefboost::adjacency_listWayPointGraph;typedefWayPointGraph::ve

c++ - Boost.Graph 如何合并两个顶点/契约(Contract)边

如何在Boost.Graph中合并两个顶点/契约边?我需要将边从顶点A移动到顶点B,并删除顶点A-是否有任何内置函数?或者adjacency_list有什么特别之处?如果没有这样的功能——那为什么呢?我认为是普通的图形操作。编辑:我确实知道可以手动执行此操作,但有一些特殊情况(如保留边缘属性),这就是为什么它是在库中的好候选者。我最想知道的是Boost.Graph是否已经有那个操作(也许有一些奇特的名字?)。如果不是-为什么这种原始操作/算法不在Graph库中。也许我遗漏了一些东西,并且该操作不是原始的或很少使用的。我不需要半生不熟的快速概念验证 最佳答案

c++ - boost::graph 中的 DFS 更改图形内容

最小的例子:#include#include#includestructvertex{intnumber;};structedge{};typedefboost::adjacency_listgraph_t;typedefboost::graph_traits::vertex_descriptorvertex_t;typedefboost::graph_traits::edge_descriptoredge_t;structvertex_visitor:publicboost::default_dfs_visitor{voiddiscover_vertex(vertex_tv,grap