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

2023 年 3 月青少年软编等考 C 语言八级真题解析

目录

  • T1. 最短路径问题
    • 思路分析
  • T2. Freda 的越野跑
    • 思路分析
  • T3. 社交网络
    • 思路分析
  • T4. 旅行
    • 思路分析

T1. 最短路径问题

题目链接:SOJ D1249

平面上有 n n n 个点( n ≤ 100 n\le 100 n100),每个点的坐标均在 − 10000 ∼ 10000 -10000\sim 10000 1000010000 之间。其中的一些点之间有连线。若有连线,则表示可从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。现在的任务是找出从一点到另一点之间的最短路径。

时间限制:1 s
内存限制:128 MB

  • 输入
    n + m + 3 n+m+3 n+m+3 行,第一行为整数 n n n
    2 2 2 行到第 n + 1 n+1 n+1 行(共 n n n 行) ,每行两个整数 x x x y y y,描述了一个点的坐标。
    n + 2 n+2 n+2 行为一个整数 m m m,表示图中连线的个数。
    此后的 m m m 行,每行描述一条连线,由两个整数 i i i j j j 组成,表示第 i i i 个点和第 j j j 个点之间有连线。
    最后一行两个整数 s s s t t t,分别表示源点和目标点。
  • 输出
    仅一行,一个实数(保留两位小数),表示从 s s s t t t 的最短路径长度。
  • 样例输入
    5
    0 0
    2 0
    2 2
    0 2
    3 1
    5
    1 2
    1 3
    1 4
    2 5
    3 5
    1 5
    
  • 样例输出
    3.41
    

思路分析

此题考查最短路径问题,属于模板题。常规情况下,最好选用 D i j k s t r a \tt Dijkstra Dijkstra 算法进行求解,不过此题数据量较小,可以使用代码更为简单的 F l o y d \tt Floyd Floyd 算法求解。

/** Name: T1.cpp* Problem: 最短路径问题* Author: Teacher Gao.* Date&Time: 2025/07/18 15:25*/#include <iostream>
#include <cmath>using namespace std;int x[105], y[105];
double g[105][105];double dis(int u, int v) {return sqrt((x[u] - x[v]) * (x[u] - x[v]) + (y[u] - y[v]) * (y[u] - y[v]));
}int main()
{ios::sync_with_stdio(false);cin.tie(0);int n, m, u, v;fill(g[0], g[0] + 105 * 105, 1e9);cin >> n;for (int i = 1; i <= n; i++) {cin >> x[i] >> y[i];g[i][i] = 0;}cin >> m;for (int i = 1; i <= m; i++) {cin >> u >> v;g[u][v] = g[v][u] = dis(u, v);}for (int k = 1; k <= n; k++)for (int i = 1; i <= n; i++)for (int j = 1; j <= n; j++)if (g[i][j] > g[i][k] + g[k][j])g[i][j] = g[i][k] + g[k][j];cin >> u >> v;printf("%.2lf", g[u][v]
http://www.dtcms.com/a/285940.html

相关文章:

  • 回归预测 | MATLAB实现DBO-BP蜣螂算法优化BP神经网络多输入单输出回归预测
  • 借助AI学习开源代码git0.7之三git-init-db
  • MyBatis-Flex代码生成
  • ARINC818协议详解
  • KRaft 角色状态设计模式:从状态理解 Raft
  • 美创科技建设项目被评为中国信通院医疗领域“磐安”优秀案例
  • A33-vstar报错记录:ERROR: build kernel Failed
  • 北京-4年功能测试2年空窗-报培训班学测开-第五十四天
  • (笔记+作业)第五期书生大模型实战营---L2G2000 GraphGen:训练数据合成实践
  • U盘运维笔记
  • 前端-CSS盒模型
  • 源鉴SCA4.9︱多模态SCA引擎重磅升级,开源风险深度治理能力再次进阶
  • world models and Human–Object Interaction (HOI)
  • Ubuntu locale命令介绍(查询和设置当前用户的语言、国家/地区以及字符编码等环境设置)
  • Windows 安装WSL +Docker 部署通义千问大模型(同步解决Ubuntu启动命令闪退)
  • 注册表单案例
  • Android性能优化之内存优化
  • HTML常见标签
  • 零售快销行业中线下巡店AI是如何颠覆传统计算机视觉识别的详细解决方案
  • Thymeleaf与Spring Boot深度集成与性能优化实战
  • 深度学习模型开发部署全流程:以YOLOv11目标检测任务为例
  • JavaScript解构性能解密:数组与对象解构的隐藏性能差异
  • 计算机视觉:AI 的 “眼睛” 如何看懂世界?
  • Sui 在非洲增长最快的科技市场开设 SuiHub Lagos 以推动创新
  • 质变科技亮相可信数据库发展大会,参编《数据库发展研究报告2025》
  • 《Python Web 框架深度剖析:Django、Flask 与 FastAPI 的选择之道》
  • web开发-HTML
  • Linux入门篇学习——借助 U 盘或 TF 卡拷贝程序到开发板上
  • Vue3 从 0 到 ∞:Composition API 的底层哲学、渲染管线与生态演进全景
  • *SFT深度实践指南:从数据构建到模型部署的全流程解析