当前位置: 首页 > news >正文

货代如何做亚马逊和速卖通网站dedecms三合一网站源码

货代如何做亚马逊和速卖通网站,dedecms三合一网站源码,网站做下载wordpress,汉中市建设工程造价信息网最近在做插件开发时,需要处理插件启动的依赖顺序,发现基于Kahn算法的拓扑排序,可以解决插件开发中的依赖顺序问题。例如针对依赖结构(如 "B":{"A"}, "C":{"A","B"}, "D&q…

最近在做插件开发时,需要处理插件启动的依赖顺序,发现基于Kahn算法的拓扑排序,可以解决插件开发中的依赖顺序问题。例如针对依赖结构(如 "B":{"A"}, "C":{"A","B"}, "D":{"A","B","C"}),可以设计兼顾数据表示入度计算环检测 的Kahn 算法接口。以下是分步设计与实现建议:


一、数据结构设计

1. 输入格式

采用 unordered_map<string, set<string>> 表示依赖关系:

  • :当前节点(如 "B"
  • :该节点依赖的父节点集合(如 {"A"}
std::unordered_map<std::string, std::set<std::string>> graph = {{"B", {"A"}},{"C", {"A", "B"}},{"D", {"A", "B", "C"}}
};
2. 内部数据结构
  • 入度表 (indegree):记录每个节点的入度(依赖数),类型为 unordered_map<string, int>
  • 邻接表 (adjacency_list):将输入转换为邻接关系,类型为 unordered_map<string, vector<string>>,存储节点到其子节点的映射(与输入方向相反)。

二、接口函数设计

1. 拓扑排序函数
std::vector<std::string> kahnTopologicalSort(const std::unordered_map<std::string, std::set<std::string>>& dependencies
);
2. 辅助步骤
  • 初始化邻接表和入度表
    遍历输入 dependencies,构建邻接表和入度表:

    std::unordered_map<std::string, std::vector<std::string>> adj;
    std::unordered_map<std::string, int> indegree;for (const auto& [node, parents] : dependencies) {for (const auto& parent : parents) {adj[parent].push_back(node); // 父节点 → 子节点indegree[node]++;            // 子节点入度增加}// 初始化无依赖的节点(入度为0)if (!indegree.count(node)) indegree[node] = 0;
    }
    
  • 队列初始化
    将入度为0的节点加入队列:

    std::queue<std::string> q;
    for (const auto& [node, degree] : indegree) {if (degree == 0) q.push(node);
    }
    
  • Kahn 核心逻辑
    依次处理队列中的节点,更新子节点入度:

    std::vector<std::string> result;
    while (!q.empty()) {auto u = q.front(); q.pop();result.push_back(u);for (const auto& v : adj[u]) {if (--indegree[v] == 0) q.push(v);}
    }
    
  • 环检测
    若结果节点数 < 总节点数,说明存在环:

    if (result.size() != indegree.size()) {throw std::runtime_error("Cycle detected!");
    }
    

三、完整代码示例

#include <iostream>
#include <vector>
#include <queue>
#include <unordered_map>
#include <set>
#include <stdexcept>std::vector<std::string> kahnTopologicalSort(const std::unordered_map<std::string, std::set<std::string>>& dependencies) {// 构建邻接表和入度表std::unordered_map<std::string, std::vector<std::string>> adj;std::unordered_map<std::string, int> indegree;// 初始化入度表(确保所有节点存在)for (const auto& [node, _] : dependencies) {indegree[node] = 0;}// 填充邻接表和入度for (const auto& [node, parents] : dependencies) {for (const auto& parent : parents) {adj[parent].push_back(node);indegree[node]++;}}// 队列初始化(入度为0的节点)std::queue<std::string> q;for (const auto& [node, deg] : indegree) {if (deg == 0) q.push(node);}// 拓扑排序std::vector<std::string> result;while (!q.empty()) {auto u = q.front(); q.pop();result.push_back(u);for (const auto& v : adj[u]) {if (--indegree[v] == 0) q.push(v);}}// 环检测if (result.size() != indegree.size()) {throw std::runtime_error("Cycle detected in dependencies!");}return result;
}int main() {std::unordered_map<std::string, std::set<std::string>> graph = {{"B", {"A"}},{"C", {"A", "B"}},{"D", {"A", "B", "C"}}};try {auto order = kahnTopologicalSort(graph);for (const auto& node : order) {std::cout << node << " ";}// 输出:A B C D(或其他合法顺序)} catch (const std::exception& e) {std::cerr << e.what() << std::endl;}return 0;
}

四、接口设计要点总结

组件作用实现方式
输入格式描述节点依赖关系unordered_map<string, set<string>>(节点 → 依赖集合)
邻接表 (adj)快速访问子节点unordered_map<string, vector<string>>(父节点 → 子节点列表)
入度表 (indegree)动态追踪依赖数量unordered_map<string, int>(节点 → 当前入度)
队列 (q)管理待处理的零入度节点std::queue
环检测确保依赖无循环结果长度 ≠ 节点总数时抛出异常

五、扩展优化建议

  1. 并行化处理
    当同一层级有多个入度为0的节点时(如 "A""B" 无依赖关系),可用线程池并行处理子节点更新。
  2. 动态更新支持
    若依赖关系实时变化,可单独封装 updateDependency() 函数,局部调整入度表而非全图重建。
  3. 字典序输出
    若需按节点名字母序输出,将队列 queue 替换为优先队列 priority_queue,但会牺牲部分时间复杂度(O(log n) 入队)。

此设计确保接口简洁且可处理复杂依赖,同时通过异常机制保障鲁棒性。实际应用中可结合具体场景选择优化方向。

http://www.dtcms.com/a/524058.html

相关文章:

  • 燃烧学课程网站建设业之峰装饰官网
  • 做料理网站关键词怎么设置上海专业的网站建设
  • 英文 PDF 文档翻译成中文的优质应用
  • css实现拼图,响应不同屏幕宽度
  • html css js网页制作成品——HTML+CSS度年华电视剧网页设计(5页)附源码
  • 告别内网限制!用StirlingPDF+cpolar打造可远程访问的PDF工具站
  • cms代码做网站高端网站设计教程
  • Tailwind CSS实战:构建仿ChatGPT聊天页面(失败了)
  • DeerFlow多智能体项目分析-依赖LangGraph实现条件路由和中断机制的源码解析
  • 【JUnit实战3_10】第六章:关于测试的质量(上)
  • 容器编排大王Kubernetes——helm包管理工具(8)
  • 南皮县网站建设php网站开发接口开发
  • 【AOA定位与UKF例程】到达角度(AOA)定位后,使用无迹卡尔曼滤波(UKF)对轨迹滤波,MATLAB例程可下载
  • 拒绝笨重,一款轻量、极致简洁的开源CI/CD工具 - Arbess
  • JavaWeb--Servlet
  • 【机器学习】15.深度聚类(Deep Clustering)原理讲解与实战
  • Atom编辑器下载安装图文教程(附安装包)
  • 【基础复习1】ROC 与 AUC:逻辑回归二分类例子
  • 【Angular 】Angular 中的依赖注入
  • 做门户网站需要什么条件文化传播公司网站模版
  • 马斯克公司推出视频模型 Imagine v0.9,实测解析
  • 扶风做企业网站网站建设平台安全问题有哪些方面
  • 【AI4S】Motif-Driven Contrastive Learning of Graph Representations
  • Flutter路由使用指南
  • husky vs lefthook:新一代 Git Hooks 工具全面对比
  • Go Web 编程快速入门 07 - 模板(1):语法与最佳实践
  • 聊城网站建设信息兴义网站建设网站建设
  • 今年前三季度浙江进出口总值首破四万亿元
  • 【一文了解】八大排序-插入排序、希尔排序
  • n8n数据存储在postgres