news 2026/5/8 2:22:58

实现最小生成树算法的Qt项目:可动态展示prim和kruskal算法的执行过程,附带报告和源代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
实现最小生成树算法的Qt项目:可动态展示prim和kruskal算法的执行过程,附带报告和源代码

算法最小生成树Qt项目 包含prim算法和kruskal算法 其中二者的执行过程可以动态展示 包含报告和源代码

最近在Qt框架下搞了个最小生成树的可视化项目,把Prim和Kruskal这两个经典算法从黑盒子里拽出来晒太阳。这个项目的核心是要让算法执行过程像看动画片一样直观——边选边动,树苗长成大树的过程尽收眼底。

先说说Prim算法的实现。核心在于维护两个阵营:已占领的节点和待攻克的节点。这里用了个取巧的边容器,每次只关注连接两个阵营的最短边:

// 这个结构体专门记录搞对象失败的边(雾) struct TempEdge { int from; int to; float weight; bool operator<(const TempEdge& other) const { return weight > other.weight; // 故意反着来,为了优先队列 } }; // 算法主循环片段 while (!minHeap.empty()) { TempEdge current = minHeap.top(); if (visited[current.to]) { minHeap.pop(); continue; } // 把这条幸运边加入MST全家福 mstEdges.append(current); // 更新占领区域 updateVisited(current.to); // 触发界面重绘信号 emit stepUpdated(); // 这里故意卡个300ms让观众看清楚 QThread::msleep(300); }

这里有个骚操作:优先队列用最大堆但是按边的权值升序排列。因为标准库的优先队列默认是最大堆,通过反转比较运算符就能白嫖这个特性。每次弹出堆顶元素时,如果目标节点已经被收编,就直接跳过,避免形成环路。

转头看看Kruskal算法的实现。这货的核心是并查集,用来判断两个节点是不是一伙的。代码里整了个PathFinder类专门干这事:

class PathFinder { QVector<int> parent; public: PathFinder(int size) : parent(size) { for(int i=0; i<size; ++i) parent[i] = i; } // 找祖宗十八代 int find(int x) { while(parent[x] != x) { parent[x] = parent[parent[x]]; // 路径压缩 x = parent[x]; } return x; } // 撮合两个帮派 bool unite(int x, int y) { int rootX = find(x); int rootY = find(y); if(rootX == rootY) return false; parent[rootX] = rootY; return true; } };

边排序这里有个坑:Qt的qSort对自定义结构不太友好,得先给边容器做个大保健:

qSort(edges.begin(), edges.end(), [](const Edge& a, const Edge& b){ return a.weight < b.weight; });

可视化部分用QGraphicsScene搭台唱戏。每个算法步骤触发信号,让视图层更新当前选中的边。比如当某条边被临幸时,会变成基佬紫并闪烁三下:

// 在图形项中处理选中状态 void EdgeItem::setState(EdgeState state) { if(state == Selected) { animation = new QPropertyAnimation(this, "color"); animation->setDuration(500); animation->setLoopCount(3); animation->setStartValue(QColor(Qt::darkMagenta)); animation->setEndValue(QColor(Qt::cyan)); animation->start(); } // 其他状态处理... }

为了让观众不睡着,算法每走一步都会通过信号槽通知界面线程更新。这里有个细节:算法跑在独立线程,通过跨线程信号触发UI刷新,避免界面假死。

项目结构上,核心代码分三大块:

  • Algorithms/里蹲着Prim和Kruskal的实现
  • Views/管图形项的绘制和动画
  • Utils/塞着并查集、优先队列这些工具人

测试时发现个邪门bug:当节点数量超过50个时,Kruskal的动画会抽风。后来发现是排序后的边容器被多个线程同时访问,加了个QMutex才镇住场子。

代码仓库里除了源码,还有个20页的报告文档,详细记录了从算法复杂度分析到Qt信号槽的线程安全注意事项。不过说实在的,最实用的还是那个能拖拽节点动态生成拓扑图的演示模式——拿这个去给学妹讲算法,效果拔群。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 17:02:44

如何为TensorFlow镜像配置持久化存储卷(Persistent Volume)

如何为TensorFlow镜像配置持久化存储卷&#xff08;Persistent Volume&#xff09; 在现代AI平台的构建中&#xff0c;一个常见的挑战是&#xff1a;如何确保长时间运行的深度学习训练任务不会因为节点重启、资源调度或意外中断而前功尽弃&#xff1f;尤其是在企业级生产环境中…

作者头像 李华
网站建设 2026/5/7 3:17:24

WebSocket实现实时反馈:基于TensorFlow镜像的互动式AI

WebSocket实现实时反馈&#xff1a;基于TensorFlow镜像的互动式AI 在智能客服系统中&#xff0c;用户刚输入一句话&#xff0c;屏幕另一端就立刻弹出精准回复&#xff1b;在工业质检流水线上&#xff0c;摄像头捕捉到产品缺陷的瞬间&#xff0c;报警信号便已传达到控制终端——…

作者头像 李华
网站建设 2026/4/23 14:30:24

【课程设计/毕业设计】基于springboot的湄潭县乡村茶产品管理系统设计与实现茶园生产、库存管理、品质溯源、销售分析【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/5 6:04:48

NFS挂载实战:TensorFlow镜像共享数据目录配置

NFS挂载实战&#xff1a;TensorFlow镜像共享数据目录配置 在企业级AI系统的开发与部署中&#xff0c;一个常见但棘手的问题浮出水面&#xff1a;如何让多个训练节点高效、一致地访问同一份大型数据集&#xff1f;尤其是在使用容器化环境时&#xff0c;每启动一个TensorFlow容器…

作者头像 李华
网站建设 2026/5/1 7:39:15

KeyBoredEvent

键盘事件按键事件 ​ 按键事件在用户按下一个键时触发&#xff0c;在Qt中使用QKeyEvent类表示这种事件。当按下一个键时&#xff0c;Qt会自动创建一个QKeyEvent对象&#xff0c;并将其传递给相应的事件处理函数。QKeyEvent对象包含该事件的详细信息 按下的键值 键值是一个枚举值…

作者头像 李华
网站建设 2026/5/7 2:49:31

如何将TensorFlow镜像整合进企业内部AI平台

如何将TensorFlow镜像整合进企业内部AI平台 在金融风控建模、工业质检系统或医疗影像分析等关键业务场景中&#xff0c;一个常见的挑战是&#xff1a;算法团队在本地训练好的模型&#xff0c;部署到生产环境后却频繁出现性能下降甚至无法运行的问题。这种“在我机器上能跑”的窘…

作者头像 李华