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

2016-PTA初赛-L3-1 天梯地图(dijkstra模板)

image

思路

dijkstra模板题,不需要小根堆优化,这题的第二个样例:路径一样则合并输出,怎么判断路径一样?会想到C++的vector对==进行了重写(即每个对应位置的元素一样)。

AcCode:

#include<iostream>
#include<cstring>
#include<vector>
using namespace std;
int N, M;
//最后一维表示time或distance,graph存图,dist存最短距,lst存上个节点
int graph[510][510][2], dist[510][2], lst[510][2];
//两种路径
vector<int> path[2];
//dijkstra模板
int dj(int st, int be, int end){dist[be][st] = 0;bool vis[510];lst[be][st] = -1;memset(vis, false, sizeof(vis));for(int i = 0; i < N; i++){int cur, mn = 0x7fffffff;for(int i = 0; i < N; i++) if(dist[i][st] < mn && !vis[i]) mn = dist[i][st], cur = i; for(int i = 0; i < N; i++){if(graph[cur][i][st] && dist[cur][st] + graph[cur][i][st] < dist[i][st] && !vis[i]){dist[i][st] = dist[cur][st] + graph[cur][i][st];lst[i][st] = cur;}}vis[cur] = true;}// for(int i = 0; i < N; i++) cout << lst[i][st] << "-";// cout << endl;return dist[end][st];
}
//递归的获取路径
void getPath(int st, int end){if(end == -1) return;getPath(st, lst[end][st]);path[st].push_back(end);
}int main(){
//初始化dist数组为大值,并不知道time和lenth取值范围,题目压根没写,我猜的。memset(dist, 0x2f, sizeof(dist));cin >> N >> M;
//输入数据while(M--){int v1, v2, ow, len, time; cin >> v1 >> v2 >> ow >> len >> time;graph[v1][v2][0] = time;graph[v1][v2][1] = len;if(ow != 1) graph[v2][v1][0] = time, graph[v2][v1][1] = len;}
//调用函数输出答案即可int be, end; cin >> be >> end;int ans[2];for(int i = 0; i < 2; i++){ans[i] = dj(i, be, end);getPath(i, end);}if(path[1] != path[0]){cout << "Time = " << ans[0] << ": ";for(int i = 0; i < path[0].size(); i++){cout << path[0][i];if(i != path[0].size() - 1) cout << " => ";}cout << endl << "Distance = " << ans[1] << ": ";for(int i = 0; i < path[1].size(); i++){cout << path[1][i];if(i != path[1].size() - 1) cout << " => ";}}else{cout << "Time = " << ans[0] << "; " << "Distance = " << ans[1] << ": ";for(int i = 0; i < path[0].size(); i++){cout << path[0][i];if(i != path[0].size() - 1) cout << " => ";}}return 0;
}
http://www.jsqmd.com/news/51023/

相关文章:

  • KEYDIY Toyota 8A (BA) 4A All-Lost Adapter Cable: Simplify Key Replacement for Mechanics Car Owners
  • PyCodeObject
  • python拷贝
  • KEYDIY KD ZB02-4 Universal Smart Remote Key 3+1 Buttons for BMW - 5pcs/lot
  • Universal 3-Button Smart Remote Key for BMW - KEYDIY KD ZB02-3 (5pcs/lot)
  • 列表,元组,字典,集合笔记
  • sam3 (3)匹配mask - MKT
  • C++学习日志——蓝桥杯课程总结_基础篇/2025.11.26
  • KEYDIY KD NB104 4-Button Universal Remote Key (5pcs) – Reliable Replacement for Euro/American Cars
  • 在 linux 操作系统中,使用 vim 打开一个文本文件时,出现中文乱码的原因和解决方法
  • 实验3类和对象
  • 【实验报告】sglang,vllm,transformers 在强制串行推理场景下的表现
  • what is A
  • 夺命雷公狗—好用的截图工具分享
  • 2025 完整 AI 模型核心用法速查表 - 智慧园区
  • 实验 3
  • pandas创建多sheets excel文件
  • 直接load Qwen2_5OmniThinkerForConditionalGeneration进行推理时eos token失灵的问题,导致不断生成重复token直至max new tokens触发
  • 第三章 哈希表part01
  • 2025年11月睫毛假发拉丝机,拉丝机,扫把丝拉丝机厂家权威推荐,细丝拉丝技术实力与口碑解析!
  • 2025年11月混凝土增强纤维丝拉丝机,睫毛假发拉丝机,拉丝机厂家权威推荐,耐磨性能与精度测评!
  • 2025年11月MBBR管材设备,PPR管材设备,PE管材设备公司推荐,管材机械专业制造与品牌保障口碑之选
  • 2025年11月PE管材设备,PPR管材设备,PVC管材设备厂商推荐:聚焦管材机械企业综合实力与核心技术
  • 使用.NET开发并上线一个小智AI对话机器人的MCP服务转接平台
  • nginx 代理的请求头设置
  • 全国最好的有机农场推荐——德芳有机农场
  • 从网页复制变化内容的一个简单方法
  • 2025年11月PMMA板片生产线,EVA板片生产线,PET板片生产线厂家权威推荐,透明板材设备品质红榜发布!
  • 2025年11月管道除锈设备,管道3pe设备,管道内壁喷粉设备厂家推荐,防腐工艺与适配管径测评!
  • 实验三 类和对象