蓝桥杯每日真题 - 第20天

devtools/2024/11/25 6:08:23/

题目:(机房)

题目描述(13届 C&C+G题)

 

解题思路:

这道题目可以看作在一个无向图中查找两点之间的最短路径。题目中的 n 台电脑和 n−1 根网线形成了一棵树,树是一个特殊的无向图,因此我们可以利用 广度优先搜索(BFS) 来求解最短路径问题。

  • 建图

    • 通过输入的 n−1 对电脑连接关系构建邻接表表示的无向图。

  • 最短路径搜索

    • 利用 BFS,从起点开始逐层扩展,找到终点时输出步数。

    • 由于树的性质,BFS的第一条找到的路径一定是最短路径。

  • 多个查询的处理

    • 每次查询直接用 BFS 求解从起点到终点的最短路径。

 

代码实现(C语言):

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int road(int start,int end,int dex,int num,int bef,int n);
int map[10000][10000];
int dey[10000];
int main()
{    int n,m;scanf("%d",&n);scanf("%d",&m);for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(i==j){map[i][j]=1;}else{map[i][j]=0;}}dey[i]=-1;}for(int i=1;i<=n-1;i++){int a;int b;scanf("%d",&a);scanf("%d",&b);map[a][b]=1;map[b][a]=1;}int q[m+1][2];for(int i=1;i<=m;i++){scanf("%d",&q[i][0]);scanf("%d",&q[i][1]);}for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){dey[i]=dey[i]+map[i][j];}}for(int i=1;i<=m;i++){printf("%d\n",road(q[i][0],q[i][1],q[i][0],0,-1,n));}return 0;
}int road(int start,int end,int dex,int num,int bef,int n)
{//printf("%d to %d have %d\n",bef,dex,num);if(dex==end){return num+dey[dex];}else{int new_num=num+dey[dex];int lin=-100;int e=0;for(int i=1;i<=n;i++){if(i!=dex && map[i][dex]==1 && i!=bef){lin=fmax(lin,road(start,end,i,new_num,dex,n));e=e+1;}}if(e==0){return -100;}else{return lin;}}
}

得到运行结果:

代码分析: 

  • 初始化部分

    • 通过输入节点数n和边数m,创建一个邻接矩阵来表示图,初始化每个节点的度数为-1。

    • 将图的边输入,并更新邻接矩阵。

  • 查询输入部分

    • 输入多个查询,每个查询要求计算从一个节点到另一个节点的路径代价。

  • 计算每个节点的度数

    • 遍历邻接矩阵,计算每个节点的度数,并将其存储在一个数组中。

  • 计算路径代价的递归函数

    • 使用深度优先搜索(DFS)递归遍历路径,如果当前节点是终点,则返回路径代价;否则,继续递归遍历与当前节点相邻的未访问节点。

    • 每到一个节点,路径代价会累加该节点的度数。

  • 输出查询结果

    • 对每个查询,调用递归函数计算路径代价,并输出结果。

难度分析

⭐️⭐️⭐️⭐️⭐️

总结

  • 图的表示:采用邻接矩阵和度数数组表示图。

  • 深度优先搜索(DFS):使用递归方法遍历路径并计算路径代价。

  • 路径代价计算:路径代价由路径上经过的所有节点的度数之和来确定。


http://www.ppmy.cn/devtools/136766.html

相关文章

el-select 和el-tree二次封装

前言 本文章是本人在开发过程中&#xff0c;遇到使用树形数据&#xff0c;动态单选或多选的需求&#xff0c;element中没有这种组件&#xff0c;故自己封装一个&#xff0c;欢迎多多指教 开发环境&#xff1a;element-UI、vue2 组件效果 单选 多选 组件引用 <treeselec…

C++知识整理day2类与对象(上)——类的定义、实例化、this指针、构造、析构、拷贝构造函数

文章目录 1.类的定义1.1 类定义的格式1.2 访问限定符1.3 类域 2.实例化2.2 对象大小 3.this指针4.类的默认成员函数5.构造函数6. 析构函数7.拷贝构造函数 1.类的定义 1.1 类定义的格式 class为定义类的关键字&#xff0c;Stu为类的名字&#xff0c;{}中为类的主体&#xff0c;…

C++ 编程指南06 - 不要泄漏任何资源

一&#xff1a;概述 资源泄漏是指程序在运行过程中分配了某些资源&#xff08;如内存、文件句柄、网络连接等&#xff09;&#xff0c;但未正确释放或归还&#xff0c;导致这些资源持续占用&#xff0c;无法被其他部分使用。 例如&#xff1a; 动态分配的内存未释放。打开的文…

理解设计模式与 UML 类图:构建稳健软件架构的基石

在软件开发的广阔天地里&#xff0c;设计模式与 UML&#xff08;统一建模语言&#xff09;类图犹如两座灯塔&#xff0c;为开发者照亮前行的道路&#xff0c;指引着我们构建出高质量、可维护且易于扩展的软件系统。今天&#xff0c;就让我们一同深入探索单一职责、开闭原则、简…

SouVR Feedback force7 力反馈设备

Feedback force7力反馈的末端执行器涵盖了人类手部的自然运动范围&#xff0c;设计与双手控制的操作台兼容。 全重力补偿和无漂移校准相结合有助于提高用户的舒适度和准确性&#xff0c;专为对于性能和可靠性至关重要的苛刻应用而设计。 产品的可靠性、可操作性、先进性 独特的…

读写分库分表

主数据库负责写&#xff0c;从数据库负责读&#xff0c;主库和从库间会进行数据同步&#xff0c;以保证库中数据的准确性。 读写分离&#xff08;极客时间Mysql45讲读写分离&#xff09; 如何实现&#xff1f; 步骤&#xff1a; 部署多台数据库&#xff0c;选择其中的一台作…

Perforce《2024游戏技术现状报告》Part3:生成式AI、版本控制、CI/CD等游戏技术的未来趋势与应用

游戏开发者一直处于创新前沿。他们的实践、工具和技术受到各行各业的广泛关注&#xff0c;正在改变着组织进行数字创作的方式。 近期&#xff0c;Perforce发布了《2024游戏技术现状报告》&#xff0c;通过收集来自游戏、媒体与娱乐、汽车和制造业等高增长行业的从业者、管理人…

241124_文本解码原理

241124_文本解码原理 一个文本序列的概率分布可以分解为每个词基于其上文的条件概率的乘积。 Greedy search 就是每步都选择概率最大的&#xff0c;不会去考虑全局 按照贪心搜索输出the nice woman 的概率就是0.5*0.40.2 这种方法简单&#xff0c;但也存在问题&#xff0c;比…