素材网站哪个好柯林建站程序

张小明 2025/12/24 20:28:21
素材网站哪个好,柯林建站程序,网站外链建设可以提升网站权重对还是错,仿it资讯类网站源码产品模块算法检验 在产品配置中#xff0c;一个配置产品是由多个产品模块(CM)构成#xff0c;每个CM有自身的算法#xff0c;且模块间可能存在算法依赖。例如电脑产品是由主板、CPU日、显卡等CM构成。CPU模块(CM1)算法依赖主板模块(CM2)算法#xff0c;记作CM2-CM1,算法…产品模块算法检验在产品配置中一个配置产品是由多个产品模块(CM)构成每个CM有自身的算法且模块间可能存在算法依赖。例如电脑产品是由主板、CPU日、显卡等CM构成。CPU模块(CM1)算法依赖主板模块(CM2)算法记作CM2-CM1,算法引擎会通过算法依赖确保此前后CM执行的顺序。如果存在模块算法循环依赖的场景那么算法引擎会报警。输入描述 输入的第一行为模块列表例如CM2CM3CM4; 输入的第二行为依赖情况,例如CM3-CM2 输出描述 计算出循环依赖的CM数量 示例1 输入 CM1,CM2,CM3,CM4,CM5,CM6 CM5-CM3,CM4-CM5,CM6-CM4,CM6-CM1,CM5-CM6 输出 3 示例2 输入 CM1,CM2,CM3,CM4,CM5,CM6 CM5-CM3,CM3-CM6,CM6-CM4,CM3-CM4,CM4-CM1 输出 0问题分析该问题需要检测模块间的循环依赖关系并计算参与循环依赖的模块数量。可以通过构建有向图并检测图中是否存在环来解决。解决思路构建有向图将每个模块表示为图的节点依赖关系表示为有向边如CM3-CM2表示从CM2指向CM3的边。检测环使用深度优先搜索DFS或拓扑排序来检测图中是否存在环。统计环中的节点如果存在环统计环中涉及的模块数量。算法实现以下是基于拓扑排序的实现方法每种语言实现逻辑一致仅语法和数据结构差异。计算每个节点的入度被依赖的次数。将入度为0的节点加入队列进行拓扑排序。若最终排序的节点数不等于总节点数则存在环。python实现from collections import defaultdict, deque def count_cyclic_dependencies(modules, dependencies): graph defaultdict(list) in_degree defaultdict(int) module_set set(modules) # 初始化入度为0 for module in module_set: in_degree[module] 0 # 构建图和入度 for dep in dependencies: dependent, dependee dep.split(-) graph[dependee].append(dependent) in_degree[dependent] 1 # 拓扑排序 queue deque() for module in module_set: if in_degree[module] 0: queue.append(module) topo_order [] while queue: node queue.popleft() topo_order.append(node) for neighbor in graph[node]: in_degree[neighbor] - 1 if in_degree[neighbor] 0: queue.append(neighbor) # 检查是否存在环 if len(topo_order) len(module_set): return 0 else: # 统计环中的节点数 # 通过反向遍历未排序的节点 cyclic_nodes module_set - set(topo_order) return len(cyclic_nodes) # 示例1 modules [CM1, CM2, CM3, CM4, CM5, CM6] dependencies [CM5-CM3, CM4-CM5, CM6-CM4, CM6-CM1, CM5-CM6] print(count_cyclic_dependencies(modules, dependencies)) # 输出3 # 示例2 modules [CM1, CM2, CM3, CM4, CM5, CM6] dependencies [CM5-CM3, CM3-CM6, CM6-CM4, CM3-CM4, CM4-CM1] print(count_cyclic_dependencies(modules, dependencies)) # 输出0Java实现import java.util.*; public class Main { public static void main(String[] args) { Scanner scanner new Scanner(System.in); String[] modules scanner.nextLine().split(,); String[] dependencies scanner.nextLine().split(,); MapString, ListString graph new HashMap(); for (String module : modules) { graph.put(module.trim(), new ArrayList()); } for (String dep : dependencies) { String[] parts dep.trim().split(-); String dependent parts[0].trim(); String dependency parts[1].trim(); graph.get(dependency).add(dependent); } SetString visited new HashSet(); SetString recursionStack new HashSet(); ListString cycleNodes new ArrayList(); for (String module : modules) { if (detectCycle(module, graph, visited, recursionStack, cycleNodes)) { break; } } System.out.println(cycleNodes.size()); } private static boolean detectCycle(String module, MapString, ListString graph, SetString visited, SetString recursionStack, ListString cycleNodes) { if (recursionStack.contains(module)) { cycleNodes.add(module); return true; } if (visited.contains(module)) { return false; } visited.add(module); recursionStack.add(module); for (String neighbor : graph.get(module)) { if (detectCycle(neighbor, graph, visited, recursionStack, cycleNodes)) { if (!cycleNodes.contains(module)) { cycleNodes.add(module); } return true; } } recursionStack.remove(module); return false; } }C实现#include iostream #include vector #include unordered_map #include unordered_set #include sstream using namespace std; bool detectCycle(const string module, unordered_mapstring, vectorstring graph, unordered_setstring visited, unordered_setstring recursionStack, vectorstring cycleNodes) { if (recursionStack.count(module)) { cycleNodes.push_back(module); return true; } if (visited.count(module)) { return false; } visited.insert(module); recursionStack.insert(module); for (const string neighbor : graph[module]) { if (detectCycle(neighbor, graph, visited, recursionStack, cycleNodes)) { if (find(cycleNodes.begin(), cycleNodes.end(), module) cycleNodes.end()) { cycleNodes.push_back(module); } return true; } } recursionStack.erase(module); return false; } int main() { string modulesStr, depsStr; getline(cin, modulesStr); getline(cin, depsStr); vectorstring modules; istringstream iss(modulesStr); string module; while (getline(iss, module, ,)) { modules.push_back(module.substr(0, module.find_last_not_of( \t) 1)); } unordered_mapstring, vectorstring graph; for (const string m : modules) { graph[m] vectorstring(); } istringstream depsIss(depsStr); string dep; while (getline(depsIss, dep, ,)) { size_t pos dep.find(-); string dependent dep.substr(0, pos); string dependency dep.substr(pos 2); dependent dependent.substr(dependent.find_first_not_of( \t)); dependency dependency.substr(dependency.find_first_not_of( \t)); graph[dependency].push_back(dependent); } unordered_setstring visited; unordered_setstring recursionStack; vectorstring cycleNodes; for (const string m : modules) { if (detectCycle(m, graph, visited, recursionStack, cycleNodes)) { break; } } cout cycleNodes.size() endl; return 0; }C实现#include stdio.h #include stdlib.h #include string.h #include stdbool.h #define MAX_MODULES 100 typedef struct { char name[10]; int edgeCount; char edges[MAX_MODULES][10]; } Module; Module graph[MAX_MODULES]; int moduleCount 0; int findModuleIndex(const char* name) { for (int i 0; i moduleCount; i) { if (strcmp(graph[i].name, name) 0) { return i; } } return -1; } bool detectCycle(int moduleIdx, bool visited[], bool recursionStack[], int* cycleSize) { if (recursionStack[moduleIdx]) { (*cycleSize); return true; } if (visited[moduleIdx]) { return false; } visited[moduleIdx] true; recursionStack[moduleIdx] true; for (int i 0; i graph[moduleIdx].edgeCount; i) { int neighborIdx findModuleIndex(graph[moduleIdx].edges[i]); if (detectCycle(neighborIdx, visited, recursionStack, cycleSize)) { if (*cycleSize 0) { (*cycleSize); return true; } } } recursionStack[moduleIdx] false; return false; } int main() { char modulesStr[1000]; fgets(modulesStr, sizeof(modulesStr), stdin); modulesStr[strcspn(modulesStr, \n)] \0; char* token strtok(modulesStr, ,); while (token ! NULL) { strcpy(graph[moduleCount].name, token); graph[moduleCount].edgeCount 0; moduleCount; token strtok(NULL, ,); } char depsStr[1000]; fgets(depsStr, sizeof(depsStr), stdin); depsStr[strcspn(depsStr, \n)] \0; token strtok(depsStr, ,); while (token ! NULL) { char* arrow strstr(token, -); if (arrow ! NULL) { char dependent[10], dependency[10]; strncpy(dependent, token, arrow - token); dependent[arrow - token] \0; strcpy(dependency, arrow 2); int depIdx findModuleIndex(dependency); strcpy(graph[depIdx].edges[graph[depIdx].edgeCount], dependent); graph[depIdx].edgeCount; } token strtok(NULL, ,); } bool visited[MAX_MODULES] {false}; bool recursionStack[MAX_MODULES] {false}; int cycleSize 0; for (int i 0; i moduleCount; i) { if (detectCycle(i, visited, recursionStack, cycleSize)) { break; } } printf(%d\n, cycleSize 0 ? cycleSize - 1 : 0); return 0; }JavaScript实现const readline require(readline); const rl readline.createInterface({ input: process.stdin, output: process.stdout }); let modules []; let dependencies []; rl.on(line, (line) { if (modules.length 0) { modules line.trim().split(,).map(m m.trim()); } else { dependencies line.trim().split(,).map(d d.trim()); solve(); rl.close(); } }); function solve() { const graph {}; modules.forEach(m { graph[m] []; }); dependencies.forEach(dep { const [dependent, dependency] dep.split(-).map(s s.trim()); graph[dependency].push(dependent); }); const visited new Set(); const recursionStack new Set(); let cycleNodes []; function detectCycle(module) { if (recursionStack.has(module)) { cycleNodes.push(module); return true; } if (visited.has(module)) { return false; } visited.add(module); recursionStack.add(module); for (const neighbor of graph[module]) { if (detectCycle(neighbor)) { if (!cycleNodes.includes(module)) { cycleNodes.push(module); } return true; } } recursionStack.delete(module); return false; } for (const module of modules) { if (detectCycle(module)) { break; } } console.log(cycleNodes.length); }代码说明输入处理解析模块列表和依赖关系构建有向图。环检测通过DFS遍历图利用递归栈判断是否存在环。结果输出统计环中模块数量并输出。若不存在环输出0。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

中国网站建设中心龙岗网站建设流程

📝 博客主页:Jax的CSDN主页 目录AI医生的逆袭之路:从“智障”到“神助攻” 一、AI医生的“成长日记”:从背锅侠到救场王 二、当AI遇上“看病难”:那些改变游戏规则的瞬间 三、AI医生的“人格分裂”:既要靠谱…

张小明 2025/12/24 17:02:39 网站建设

专业做网站排名公司电话安徽建设工程信息网查询

文章目录前言1. 安装Docker2. 本地部署HivisionIDPhotos3. 公网远程访问制作照片3.1 内网穿透工具安装3.2 创建远程连接公网地址4. 配置固定公网地址前言 HivisionIDPhotos 是一款 AI 证件照制作工具,能自动抠图、调整尺寸和背景,生成符合各种规格的证件…

张小明 2025/12/25 3:05:01 网站建设

重庆做网站做网站用的主机

前言 本个人理财系统管理员功能有个人中心,用户管理,账单类型管理。用户功能有个人中心,收入账单管理,支出账单管理,理财计划管理,统计分析管理,备忘录管理等。因而具有一定的实用性。 本站是一…

张小明 2025/12/24 19:37:23 网站建设

做网站要注意什么电子商务网站建设作业代码

AI Agent是将大模型与工具、记忆、执行系统结合的智能体,具有自主决策、持续学习、多模态交互、工具集成和多智能体协作五大特征。其技术架构包含感知、决策、执行、记忆和反馈优化六大模块。AI Agent改变了从"告诉机器怎么做"到"告诉机器想要什么&q…

张小明 2025/12/25 3:20:25 网站建设

网站备案后 还是需要再备案吗网站建设企业号助手

破解负载不均难题-多 Agent 系统的复杂度感知调度方案 一、背景与问题引入 随着 多 Agent 系统(Multi-Agent System, MAS) 在智能体协作、自动化运维、智能搜索、LLM Agent 编排等场景中的广泛应用,系统规模迅速扩大,一个现实问题…

张小明 2025/12/24 17:04:35 网站建设

义乌公司网站建设asp网站安全吗

当别人还在用ChatGPT闲聊时,懂行的人已经用它改写了职业轨迹。 深夜,一位从事传统软件开发的工程师小李,在调试完最后一个API接口后,习惯性地点开了GitHub Trending。排行榜前列,与大模型相关的开源项目几乎占据了半壁…

张小明 2025/12/24 20:45:28 网站建设