1111 Online Map(30分)

题目翻译:

就是求解一个点到另一个点的最短路径。

不过由于限制条件很多,还得分开求两次,所以写起来就很繁。

题解思路:

可以用dijkstra或者dfs,用后者的话最后一个测试点可能会超时。

代码:

dfs(最后一个测试点超时):

#include<bits/stdc++.h>
using namespace std;
int N, M;//结点数量,边的数量
vector<int> v[501];
int dis[501][501];
int cost[501][501];
int mindis[501];
int min_len = INT_MAX, min_cost = INT_MAX;
vector<int> path1, path2, temp;
int so, des;
int temp_cost = INT_MAX;void dfs(int curnode, int curlen,int curcost)
{if (curlen > mindis[curnode]) return;elsemindis[curnode] = curlen;temp.push_back(curnode);if (curnode == des){if (curlen < min_len){min_len = curlen;path1 = temp;temp_cost = curcost;}if (curlen == min_len&&curcost<temp_cost)path1 = temp;}else {for (auto i : v[curnode])dfs(i, curlen + dis[curnode][i], curcost + cost[curnode][i]);}temp.pop_back();
}void dfs2(int curnode, int curlen)
{if (curlen > mindis[curnode]) return;elsemindis[curnode] = curlen;temp.push_back(curnode);if (curnode == des){if (curlen < min_cost){min_cost = curlen;path2 = temp;}if (curlen == min_cost && temp.size() < path2.size())path2 = temp;}else {for (auto i : v[curnode])dfs2(i, curlen + cost[curnode][i]);}temp.pop_back();
}int main()
{cin >> N >> M;int q, w, e, r, t;for (int i = 0;i < M;i++){cin >> q >> w >> e >> r >> t;if (e)//单向{v[q].push_back(w);dis[q][w] = r;cost[q][w] = t;}else//双向{v[q].push_back(w);v[w].push_back(q);dis[q][w] = dis[w][q] = r;cost[q][w] = cost[w][q] = t;}}for (int i = 0;i < 501;i++)mindis[i] = INT_MAX;cin >> so >> des;dfs(so, 0, 0);for (int i = 0;i < 501;i++)mindis[i] = INT_MAX;temp.clear();dfs2(so, 0);if (path1 != path2){cout << "Distance = " << min_len << ":";for (int i = 0;i < path1.size();i++){if (i)cout << " ->";cout << " " << path1[i];}cout << endl;}elsecout << "Distance = " << min_len << "; ";cout << "Time = " << min_cost << ":";for (int i = 0;i < path2.size();i++){if (i)cout << " ->";cout << " " << path2[i];}
}

dijkstra(AC,转载于AC代码 )

#include<bits/stdc++.h>
using namespace std;int n, m, source, dest, min_distance, min_time;
vector<int> ans_t, ans_d, dpre(500, -1), tpre(500, -1);
vector<vector<int>> times(500, vector<int>(500, -1)), distances(500, vector<int>(500, -1)), graph(500,vector<int>(500, 0));
void dfs1(int x){if(x == -1) return;dfs1(dpre[x]);ans_d.push_back(x);
}
void dfs2(int x){if(x == -1) return;dfs2(tpre[x]);ans_t.push_back(x);
}
void dijkstra1(int beg){vector<int> lowcost(500, 0x3f3f3f3f), vis(500, 0), dtime(500, 0x3f3f3f3f);lowcost[beg] = 0;dpre[beg] = -1;for (int i = 0; i < n;i++){int Min = 0x3f3f3f3f, k = -1;for (int j = 0; j < n;j++){if(vis[j] == 0 && lowcost[j] < Min){Min = lowcost[j];k = j;}}if(k == -1) break;vis[k] = 1;for (int j = 0; j < n;j++){if(vis[j] == 0 && graph[j][k] == 1){//如果满足条件则更新信息,这里要注意逻辑短路现象if(lowcost[j] > lowcost[k] + distances[j][k] || (lowcost[j] == lowcost[k] + distances[j][k] && dtime[k] + times[k][j] < dtime[j])){dpre[j] = k;dtime[j] = dtime[k] + times[k][j];lowcost[j] = lowcost[k] + distances[j][k];}}}}min_distance = lowcost[dest];dfs1(dest);
}void dijkstra2(int beg){vector<int> lowcost(500, 0x3f3f3f3f), vis(500, 0), intersections(500, 0x3f3f3f3f);lowcost[beg] = 0;tpre[beg] = -1;for (int i = 0; i < n;i++){int Min = 0x3f3f3f3f, k = -1;for (int j = 0; j < n;j++){if(vis[j] == 0 && lowcost[j] < Min){Min = lowcost[j];k = j;}}if(k == -1) break;vis[k] = 1;for (int j = 0; j < n;j++){if(vis[j] == 0 && graph[j][k] == 1){if(lowcost[j] > lowcost[k] + times[j][k] || (lowcost[j] == lowcost[k] + times[j][k] && intersections[k] + 1 < intersections[j])){tpre[j] = k;intersections[j] = intersections[k] + 1;lowcost[j] = lowcost[k] + times[j][k];}}}}min_time = lowcost[dest];dfs2(dest);
}int main(){int s, e, a, l, t, isSame = 1;cin >> n >> m;for (int i = 0; i < m;i++){cin >> s >> e >> a >> l >> t;graph[s][e] = graph[e][s] = 1;times[s][e] = times[e][s] = t;distances[s][e] = distances[e][s] = l;}cin >> source >> dest;dijkstra1(source);dijkstra2(source);if(ans_d.size() == ans_t.size()){for (int i = 0; i < ans_t.size();i++){if(ans_t[i] != ans_d[i]){isSame = 0;break;//能省点时间就省点}}}elseisSame = 0;if(isSame == 0){printf("Distance = %d: %d", min_distance, ans_d[0]);for (int i = 1; i < ans_d.size();i++)printf(" -> %d", ans_d[i]);printf("\nTime = %d: %d", min_time, ans_t[0]);for (int i = 1; i < ans_t.size();i++)printf(" -> %d", ans_t[i]);}else{printf("Distance = %d; Time = %d: %d", min_distance, min_time, ans_t[0]);for (int i = 1; i < ans_t.size();i++)printf(" -> %d", ans_t[i]);}cout << endl;return 0;
}

坑点:

测试点4用dfs可能会超时

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/127856.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vins-Fusion、Vins-Mono(之前那个编译通过但是没有这个好用)

ROS的catkin_make不要修改,暂时没有理由&#xff0c;理由就是两次一个改了一个没改&#xff0c;没改的成功了以成功为准。 另外docker也没用成功&#xff0c;原本的逻辑来说&#xff0c;docker肯定不能出问题的&#xff0c;但是由于roscore通信的原因可能没有将结果显示&#x…

二叉树问题——前/中/后/层遍历问题(递归与栈)

摘要 博文主要介绍二叉树的前/中/后/层遍历(递归与栈)方法 一、前/中/后/层遍历问题 144. 二叉树的前序遍历 145. 二叉树的后序遍历 94. 二叉树的中序遍历 102. 二叉树的层序遍历 103. 二叉树的锯齿形层序遍历 二、二叉树遍历递归解析 // 前序遍历递归LC144_二叉树的前…

Spring Cloud Gateway 重写 URL

目录 1、简介 2、Spring Cloud Gateway 快速回顾 3、基于配置的 URL 重写 4、基于 DSL 的 URL 重写 5、测试 6、总结 1、简介 Spring Cloud Gateway 的常见用例是作为一个网关&#xff0c;代理一个或多个服务&#xff0c;从而为客户端提供更简单的消费方式。 本文将带你…

数学+分类讨论+构造:1102T3

http://cplusoj.com/d/senior/p/SS231102C 首先可以通过枚举逆序对点的贡献推出无解情况为 n m o d 4 > 1 n \bmod 4 > 1 nmod4>1 然后构造可以按 n m o d 3 n\bmod 3 nmod3 进行分类 #include<bits/stdc.h> using namespace std; #ifdef LOCAL#define deb…

Linux的test测试功能

测试文件名的类型&#xff0c;文件是否存在&#xff0c; 文件的权限检测 文件之间的比较 两个整数之间的比较 判断字符串数据 多重条件判定 一个一个来&#xff0c;这个有点多&#xff0c;不过比较有意思&#xff0c;来代码 案例1&#xff0c;判断文件是否存在&#xff…

超声波俱乐部分享:百度世界大会点燃AI创业者新希望

10月22日&#xff0c;2023年第十三期超声波俱乐部内部分享会在北京望京举行。本期的主题是&#xff1a;百度世界大会点燃AI创业者新希望。 到场的嘉宾有&#xff1a;超声波创始人杨子超&#xff0c;超声波联合创始人、和牛商业创始人刘思雨&#xff0c;中国国际经济交流中心研…

excel利用正则匹配和替换指定内容

上班中, 突然接到电话, 屋里的上司大人发来个excel, 说要替换里面x-x-xxx列的内容为x栋x单元xxx. 大致表格如下, 原表格我就不发了 身为程序猿的我, 肯定第一就想到了 正则! 打开excel-开始-查找和替换, 我擦, 只能完全匹配和替换 比如一次只能替换1-1- -> 为1栋1单元 1-2…

Java 零碎知识点

目录 [多线程]创建多线程的三种方式 [网络编程]一、重点概念1、TCP/IP网络模型2、IP 对象3、端口号4、协议UDP(User Datagram Protocol)TCP(Transmission Control Protocol) 二、UDP 通信三、TCP 通信 [前端][Vue]一、Vue3项目创建响应式函数父子通信父传子子传父 跨层组件通信…

Java规则引擎2.1.8版本新增功能说明

规则引擎更新功能 新增: 1.决策结束节点新增结果导出excel功能&#xff1b; 在决策流程的结束节点&#xff0c;可以将决策结果导出为Excel文件。这个功能为用户提供了更多的灵活性和便利性&#xff0c;使他们能够轻松地将决策结果数据进行进一步的分析和处理。 2.新增公有变…

@所有人,城市燃气信息化与信息安全建设方法

关键词&#xff1a;城市燃气信息化、智慧燃气建设、城市燃气安全、智慧燃气、智慧燃气平台 近几年&#xff0c;燃气作为一种新兴的燃料迅速普及开来&#xff0c;和燃气有关的企业之间的竞争也不可避免。身处在互联网的时代&#xff0c;企业只有顺应时代的潮流&#xff0c;将城…

代码最佳实践和指南(四)

错误处理和测试 错误处理和测试的重要性 测试你的代码是必要的&#xff0c;以确保你的代码正在做你认为它应该做的事情。尝试用小的、虚构的数据集测试你的代码&#xff0c;在那里你知道结果应该是什么&#xff0c;并检查你的程序是否给出了预期的答案。如果你有时间和资源&a…

SpringBoot 继承 Apollo 应用 简单步骤记录

1、pom.xml 添加依赖&#xff1b; <!--本地项目涉及到该sdk版本冲突时可能需要手动解决版本控制问题--><dependency><groupId>com.ctrip.framework.apollo</groupId><artifactId>apollo-client-tair</artifactId><version>1.4.0<…

概念解析 | 神经网络中的位置编码(Positional Encoding)

注1:本文系“概念解析”系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:Positional Encoding 神经网络中的位置编码(Positional Encoding) A Gentle Introduction to Positional Encoding in Transformer Models, Part 1 1.背景介绍 在自然语言处理任…

通过xshell传输文件到服务器

一、user is not in the sudoers file. This incident will be reported. 参考链接&#xff1a; [已解决]user is not in the sudoers file. This incident will be reported.(简单不容易出错的方式)-CSDN博客 简单解释下就是&#xff1a; 0、你的root需要设置好密码 sudo …

Java实验二类编程实验

1.编写一个代表三角形的类&#xff08;Triangle.java&#xff09;。 其中&#xff0c;三条边a,b,c&#xff08;数据类型为double类型&#xff09;为三角形的属性&#xff0c;该类封装有求三角形的面积和周长的方法。分别针对三条边为3、4、5和7、8、9的两个三角形进行测试&…

Web Woeker和Shared Worker的使用以及案例

文章目录 1、前言2、介绍 Web Worker3、使用须知及兼容性3.1、使用须知3.2、兼容性 4、使用 Web Worker4.1、创建 Web Worker4.2、与主线程通信4.3、终止 Web Worker4.4、监听错误信息 5、使用 Shared Worker4.5、调试 Shared Worker 6、使用中的一些坑6.1、Web Woeker 中引入了…

古老的五子棋

午休忽然想起我奶奶喜欢下的一种古老的五子棋游戏&#xff0c;于是花了半小时开发出来了&#xff5e; 源代码&#xff1a; <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" …

怎么监控钉钉聊天记录内容(监控钉钉聊天记录的3种形式)

企业沟通工具的普及&#xff0c;越来越多的企业开始使用钉钉作为内部沟通工具。然而&#xff0c;对于企业管理者来说&#xff0c;如何监控钉钉聊天记录内容成为了一个重要的问题。本文将介绍几种方法&#xff0c;帮助企业管理者实现监控钉钉聊天记录内容的目的。 一、钉钉自带功…

电商api数据采集分析(淘宝价格监控)

一、什么是淘宝商品数据采集&#xff1f; 淘宝商品数据采集&#xff0c;顾名思义&#xff0c;就是通过技术手段对全网电商平台上的商品价格信息进行抓取并保存。通过将收集到的这些价格信息进行分析处理后得到该商品的成交价、折扣率等关键属性指标&#xff0c;从而为卖家提供参…

系列十五、idea全局配置

一、全局Maven配置 IDEA启动页面>Customize>All settings>Build,Execution,Deployment>Build Tools>Maven 二、全局编码配置 IDEA启动页面>Customize>All settings>Editor>File Encodings 三、全局激活DevTools配置 IDEA启动页面>Customize>A…