博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷 P1744(迪杰斯特拉)
阅读量:6348 次
发布时间:2019-06-22

本文共 1719 字,大约阅读时间需要 5 分钟。

题目大概是这样的:

题目背景

《爱与愁的故事第三弹·shopping》第一章。

题目描述

中山路店山店海,成了购物狂爱与愁大神的“不归之路”。中山路上有n(n<=100)家店,每家店的坐标均在-10000~10000之间。其中的m家店之间有通路。若有通路,则表示可以从一家店走到另一家店,通路的距离为两点间的直线距离。现在爱与愁大神要找出从一家店到另一家店之间的最短距离。你能帮爱与愁大神算出吗?

输入输出格式

输入格式:

 

共n+m+3行:

第1行:整数n

第2行~第n+1行:每行两个整数x和y,描述了一家店的坐标

第n+2行:整数m

第n+3行~第n+m+2行:每行描述一条通路,由两个整数i和j组成,表示第i家店和第j家店之间有通路。

第n+m+3行:两个整数s和t,分别表示原点和目标店

 

输出格式:

 

仅一行:一个实数(保留两位小数),表示从s到t的最短路径长度。

题解

某天我把白书(信息学奥赛一本通)上的迪杰斯特拉例题打了一遍,结果没过几天就翻到这个题,把白书上的代码原样提交上去之后,居然A了...

#include
using namespace std; int n,i,j,k,x,y,m,s,e;int a[101][3]; //存坐标 double c[101]; //c[i]表示s到i的最短距离bool b[101]; //b[i]判断是否走过 double f[101][101]; //f[i][j]表示i,j距离 double minl; double maxx=1e30; //初始化时使用 int main(){ cin>>n; //输入几个点 for(i=1;i<=n;i++) //输入每个点的坐标 cin>>a[i][1]>>a[i][2]; for(i=1;i<=n;i++) for(j=1;j<=n;j++) f[i][j]=maxx; //初始化 cin>>m; //输入有几条边 for(i=1;i<=m;i++) //输入每一条边 { cin>>x>>y; f[x][y]=f[y][x]=sqrt(pow(double(a[x][1]-a[y][1]),2) +pow(double(a[x][2]-a[y][2]),2)); //pow(x,y)求x的y次方 } //预处理长度 cin>>s>>e; //输入起点终点 for(i=1;i<=n;i++) c[i]=f[s][i]; //初始化可以直接到的点 memset(b,false,sizeof(b));//都没走过 b[s]=true; //自身走过 c[s]=0; //到自己长度为0 for(i=1;i<=n-1;i++) { minl=maxx; //初始化为无限大,保证一会可以被更新 k=0; //记录是否更新,与可拓展中最小长度的节点下标 for(j=1;j<=n;j++) if((!b[j])&&(c[j]

所以说看书是个好东西...

转载于:https://www.cnblogs.com/Alarak26/p/8551969.html

你可能感兴趣的文章
linux下SSH远程连接服务慢解决方案
查看>>
利用mic visual studio 2010 编译器执行wincap获取网络适配器的代码
查看>>
HTML
查看>>
CENTOS7下编译安装PHP-5.4以及配置phpMyAdmin
查看>>
磁盘显示无法访问拒绝访问,里面的资料怎样找到
查看>>
Java之品优购课程讲义_day07(5)
查看>>
Java的新项目学成在线笔记-day3(八)
查看>>
Windows 下 Python 3.6 下安装 TensorFlow (屡败屡战)
查看>>
路由简单的实验
查看>>
Centos6.4 xen编译部署
查看>>
好程序员web前端教程分享js reduce方法使用教程
查看>>
零基础学习大数据Hadoop需要什么准备?Hadoop如何发展起来的?
查看>>
前端程序员需要具备的几个软实力,你具备了吗
查看>>
RHEL系列网络配置2015083101
查看>>
c# 基本值类型及其默认值
查看>>
服务器端解决JS跨域调用问题
查看>>
迁移至个人blog
查看>>
MySql中添加用户,新建数据库,用户授权,删除用户,修改密码
查看>>
雨巷-戴望舒
查看>>
OpenCms创建网站过程图解——献给OpenCms的初学者们
查看>>