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

医疗网站建设流程排名优化网站建设

医疗网站建设流程,排名优化网站建设,招标网站排名前十名,logo设计大赛网站class Grapg<T> {// 用于存储所有的顶点verteces: T[] [];// 用于存储所有的边 采用邻接表的形式adjList: Map<T, T[]> new Map();// 添加顶点addVertex(v: T) {this.verteces.push(v);// 初始化顶点的邻接表this.adjList.set(v, []);}// 添加边addEdge(v: T, w:…
class Grapg<T> {// 用于存储所有的顶点verteces: T[] = [];// 用于存储所有的边 采用邻接表的形式adjList: Map<T, T[]> = new Map();// 添加顶点addVertex(v: T) {this.verteces.push(v);// 初始化顶点的邻接表this.adjList.set(v, []);}// 添加边addEdge(v: T, w: T) {// 有向图 只需要添加单向的边this.adjList.get(v)?.push(w);// 无向图 需要添加反向的边this.adjList.get(w)?.push(v);}// 打印图printEdges() {// 遍历所有的顶点this.verteces.forEach((vertex) => {// 打印顶点和它的邻接表console.log(`${vertex} -> ${this.adjList.get(vertex)?.join(' ')}`);});}// 广度优先遍历BFS() {if (this.verteces.length === 0) return;const visited = new Set<T>(); // 用于存储已经访问过的顶点visited.add(this.verteces[0]); // 从第一个顶点开始遍历const queue = [this.verteces[0]]; // 用于存储待访问的顶点// 队列不为空时while (queue.length) {const v = queue.shift()!; // 取出队列的第一个顶点console.log(v); // 打印顶点const vEdges = this.adjList.get(v); // 获取该顶点的邻接表// 如果没有邻接表 则跳过if (!vEdges) continue;// 从前往后遍历for (const e of vEdges) {// 如果没有访问过 就入队列if (!visited.has(e)) {visited.add(e);queue.push(e);}}}}// 深度优先遍历DFS() {if (this.verteces.length === 0) return;const visited = new Set<T>(); // 用于存储已经访问过的顶点visited.add(this.verteces[0]); // 从第一个顶点开始遍历const stack = [this.verteces[0]]; // 用于存储待访问的顶点// 栈不为空时while (stack.length) {const v = stack.pop()!; // 取出栈顶的顶点console.log(v); // 打印顶点const vEdges = this.adjList.get(v); // 获取该顶点的邻接表if (!vEdges) return; // 如果没有邻接表 则跳过// 从后往前遍历for (let i = vEdges.length - 1; i >= 0; i--) {const e = vEdges[i]; // 获取顶点// 如果没有访问过 就入栈if (!visited.has(e)) {stack.push(e);visited.add(e);}}}}
}const graph = new Grapg<string>();
// 添加A-I的顶点
for (let i = 0; i < 9; i++) {graph.addVertex(String.fromCharCode(65 + i));
}
// 添加边
graph.addEdge('A', 'B');
graph.addEdge('A', 'C');
graph.addEdge('A', 'D');
graph.addEdge('C', 'D');
graph.addEdge('C', 'G');
graph.addEdge('D', 'G');
graph.addEdge('D', 'H');
graph.addEdge('B', 'E');
graph.addEdge('B', 'F');
graph.addEdge('E', 'I');
graph.printEdges();
console.log('BFS');
graph.BFS();
console.log('DFS');
graph.DFS();

在这里插入图片描述

http://www.zhongyajixie.com/news/39027.html

相关文章:

  • php网站开发实训心得快速网站轻松排名哪家好
  • 十大纯净系统网站长春关键词优化平台
  • 郑州工作汤阴县seo快速排名有哪家好
  • 做网站用com还是cn好东台网络推广
  • 如何用eclipse做网站站长之家域名查询排行
  • 网站建设发展方向怎么写深圳seo优化
  • 企业网站建设版本安卓手机优化软件哪个好
  • 在网站后台设置wap模板目录代写文案的软件
  • 山东省政府采购网 网站建设 招标刚刚发生了一件大事
  • 郑州专业的网站建设公司google关键词排名优化
  • 容易导致网站作弊的几个嫌疑免费百度seo引流
  • 漫画网站源码青岛seo代理计费
  • 大型网站域名so导航 抖音
  • 做招聘的网站有哪些内容百度竞价广告点击器
  • 大连网站推广价格优化系统
  • 金融公司网站建设hao123网址之家官网
  • 网站做防劫持百度竞价代运营外包
  • 网站的模糊搜索怎么做seo搜索排名优化
  • 不知此网站做男人也百度竞价sem
  • 权威的公司网站制作十大经典事件营销案例分析
  • 东莞网站制作公司是什么朋友圈产品推广文案
  • 青岛网站设计网站网站的开发流程
  • 佘山网站建设seo免费诊断
  • 惠州专业做网站成品网站源码在线看
  • 做程序网站需要什么代码沈阳头条今日头条新闻最新消息
  • 深圳公司网站如何设计品牌网
  • 学习做网站可以吗怎么在百度上发布信息广告
  • 用html做登录网站北京seo优化
  • python做视频点播网站免费宣传平台有哪些
  • 北京做网站优化媒体平台