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

湘潭市网站建设_网站建设公司_SEO优化_seo优化

微信网站技术方案,深圳市南山网站建设,做外销网站,注册个体工商户用于网站建设题目背景 B 地区在地震过后#xff0c;所有村庄都造成了一定的损毁#xff0c;而这场地震却没对公路造成什么影响。但是在村庄重建好之前#xff0c;所有与未重建完成的村庄的公路均无法通车。换句话说#xff0c;只有连接着两个重建完成的村庄的公路才能通车#xff0c;…题目背景 B 地区在地震过后所有村庄都造成了一定的损毁而这场地震却没对公路造成什么影响。但是在村庄重建好之前所有与未重建完成的村庄的公路均无法通车。换句话说只有连接着两个重建完成的村庄的公路才能通车只能到达重建完成的村庄。 题目描述 给出 B 地区的村庄数 N村庄编号从 0 到 N−1和所有 M 条公路的长度公路是双向的。并给出第 i 个村庄重建完成的时间 ti​你可以认为是同时开始重建并在第 ti​ 天重建完成并且在当天即可通车。若 ti​ 为 0 则说明地震未对此地区造成损坏一开始就可以通车。之后有 Q 个询问 (x,y,t)对于每个询问你要回答在第 t 天从村庄 x 到村庄 y 的最短路径长度为多少。如果无法找到从 x 村庄到 y 村庄的路径经过若干个已重建完成的村庄或者村庄 x 或村庄 y 在第 t 天仍未重建完成则需要输出 −1。 输入格式 第一行包含两个正整数 N,M表示了村庄的数目与公路的数量。 第二行包含 N 个非负整数 t0​,t1​,⋯,tN−1​表示了每个村庄重建完成的时间数据保证了 t0​≤t1​≤⋯≤tN−1​。 接下来 M 行每行 3 个非负整数 i,j,ww 为不超过 10000 的正整数表示了有一条连接村庄 i 与村庄 j 的道路长度为 w保证 j≠i且对于任意一对村庄只会存在一条道路。 接下来一行也就是 M3 行包含一个正整数 Q表示 Q 个询问。 接下来 Q 行每行 3 个非负整数 x,y,t询问在第 t 天从村庄 x 到村庄 y 的最短路径长度为多少数据保证了 t 是不下降的。 输出格式 共Q 行对每一个询问 (x,y,t) 输出对应的答案即在第 t 天从村庄 x 到村庄 y 的最短路径长度为多少。如果在第 t 天无法找到从 x 村庄到 y 村庄的路径经过若干个已重建完成的村庄或者村庄 x 或村庄 y 在第 t 天仍未修复完成则输出 −1。 输入输出样例 输入 #1复制 4 5 1 2 3 4 0 2 1 2 3 1 3 1 2 2 1 4 0 3 5 4 2 0 2 0 1 2 0 1 3 0 1 4 输出 #1复制 -1 -1 5 4 说明/提示 对于 30% 的数据有 N≤50对于 30% 的数据有 ti​0其中有 20% 的数据有 ti​0 且 N50对于 50% 的数据有 Q≤100对于 100% 的数据有 1≤N≤20020≤M≤2N×(N−1)​1≤Q≤50000所有输入数据涉及整数均不超过 105。 解析 这题一看就是图论的问题阅读完题目后村庄的修建时间是不减递增的。后面的询问时间也是递增的。 在联想到最短路问题有Floyd算法可以很快的求出最短路径其数据也没有那么大。 这是一道不错的Floyd算法的运用。 普通的Floyd算法是三层for循环dp[i][j]   min(dp[i][k],dp[k][j],dp[i][j]); for(k1;kn;k)for(i1;in;i)for(j1;jn;j)if(e[i][j]e[i][k]e[k][j])e[i][j]e[i][k]e[k][j]; 从i地点到k,在从k到达j。 所有的边全部给出按照时间顺序更新每一个可用的点即修建好村庄对于每个时间点进行两点之间询问求对于目前建设的所有村庄来说任意两点之间的最短路 不正好就是Floyd算法中使用前k个节点更新最短路的思维吗 核心代码 inline void updata(int k){ //以k为中心的点进行更新for(int i 0;i n;i){for(int j 0;j n;j){if(f[i][j] f[i][k] f[j][k]){f[i][j] f[j][i] f[i][k] f[k][j];}}}return; } 代码 #includebits/stdc.h using namespace std; #define N 205 #define endl \n int n,m; int a[N]; int f[N][N]; inline void updata(int k){for(int i 0;i n;i){for(int j 0;j n;j){if(f[i][j] f[i][k] f[j][k]){f[i][j] f[j][i] f[i][k] f[k][j];}}}return; } int main() {cin n m;for(int i 0;i n;i){scanf(%d,ai);}for(int i 0;i n;i){ //初始化 for(int j 0;j n;j){f[i][j] 1e9;}}for(int i 0;i n;i) {f[i][i] 0;}int s1,s2,s3;for(int i 1;i m;i){ //从s1 - s2 的距离 scanf(%d%d%d,s1,s2,s3);f[s1][s2] f[s2][s1] s3;}int q;cin q;int now 0;for(int i 1;i q;i){scanf(%d%d%d,s1,s2,s3);while(a[now] s3 now n){ //now是指遍历到那个节点 updata(now);now;}if(a[s1] s3||a[s2] s3) cout -1endl;else{if(f[s1][s2] 1e9) cout -1 endl;else cout f[s1][s2] endl;}}return 0; } //4 5 //1 3 3 4 //0 2 1 //2 3 1 //3 1 2 //2 1 4 //0 3 5 //4 //2 0 2 //0 1 2 //0 1 3 //0 1 4
http://www.ihoyoo.com/news/48291.html

相关文章:

  • 建网站需要什么条件亚马逊做品牌备案自有网站
  • 个人网站营业执照wordpress内页显示副标题
  • 网站建设工资企业查询天眼查免费
  • 网站的项目建设周期门户网站运营
  • 长沙做网站一般要多少钱谷歌seo运营
  • 学习网站建设论文福州 网站设计
  • 佛山专业网站制作设计优化方案物理必修三电子版
  • 网站建设168关于建设工程招标类的公共网站
  • 个人网站开发与设计摘要社交(sns)网站的完整设计思路
  • 用备案的网站做违法网站安卓开发培训机构
  • 阿里云上能建设自己的企业网站厦门软件开发工资一般多少
  • 做视频网站视频短片电商网站开发 思维导图
  • 国外网站关键词wordpress is tag
  • 新乡+网站建设北京网站建设公司华网天下
  • 免费做橙光封面的网站广东省高校质量工程建设网站
  • 网站搜索引擎优化方案论文今天最新体育新闻
  • 做搜狗手机网站快速排网站导航用什么字体
  • 环保网站建设费用互联网项目网
  • 做网站从哪里找货源提高审美网站
  • 基本建筑网站承德市兼职网招聘信息
  • 公司手机网站制作没有网站可以做百度直通车吗
  • 郑州计算机网站公司小程序开发多少钱
  • 随州网站推广哪家专业做网站推广要多少钱
  • 网站设计欣赏国外wordpress教程ftp
  • 启动网站集约化建设wordpress自定义图片
  • 企业品牌推广网站潍坊网页模板建站
  • 车工订单网站网站建设模板删不掉
  • 湖南沙坪建设有限公司网站ip地址免费
  • 深圳网站订制开发什么软件可以攻击网站
  • 做班级相册网站的目的意义互联网建设发展