洛谷——P1346 电车
2024-09-04 12:55:44
P1346 电车
题目描述
在一个神奇的小镇上有着一个特别的电车网络,它由一些路口和轨道组成,每个路口都连接着若干个轨道,每个轨道都通向一个路口(不排除有的观光轨道转一圈后返回路口的可能)。在每个路口,都有一个开关决定着出去的轨道,每个开关都有一个默认的状态,每辆电车行驶到路口之后,只能从开关所指向的轨道出去,如果电车司机想走另一个轨道,他就必须下车切换开关的状态。
为了行驶向目标地点,电车司机不得不经常下车来切换开关,于是,他们想请你写一个程序,计算一辆从路口A到路口B最少需要下车切换几次开关。
输入输出格式
输入格式:
第一行有3个整数2<=N<=100,1<=A,B<=N,分别表示路口的数量,和电车的起点,终点。
接下来有N行,每行的开头有一个数字Ki(0<=Ki<=N-1),表示这个路口与Ki条轨道相连,接下来有Ki个数字表示每条轨道所通向的路口,开关默认指向第一个数字表示的轨道。
输出格式:
输出文件只有一个数字,表示从A到B所需的最少的切换开关次数,若无法从A前往B,输出-1。
输入输出样例
输入样例#1: 复制
3 2 1 2 2 3 2 3 1 2 1 2
这个题就是题目稍微难懂一点,然后这个题的关键就是建图了,根据题目中所描述的,我们把每个点向他的第一条边连边权为0的边,向剩下的点连边权为1的边,然后跑最短路就好了
#include<queue> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define N 10010 #define maxn 9999999 using namespace std; queue<int>q; bool vis[N]; int n,a,b,x,t,y,tot,dis[N],head[N]; int read() { ,f=; char ch=getchar(); ;ch=getchar();} +ch-',ch=getchar(); return x*f; } struct Edge { int to,dis,next; }edge[N]; int add(int x,int y,int z) { tot++; edge[tot].to=y; edge[tot].dis=z; edge[tot].next=head[x]; head[x]=tot; } int spfa(int s) { ;i<=n;i++) dis[i]=maxn,vis[i]=; vis[s]=,q.push(s); while(!q.empty()) { x=q.front();q.pop();vis[x]=false; for(int i=head[x];i;i=edge[i].next) { int t=edge[i].to; if(dis[t]>dis[x]+edge[i].dis) { dis[t]=dis[x]+edge[i].dis; if(!vis[t]) q.push(t),vis[t]=true; } } } } int main() { n=read(),a=read(),b=read(); ;i<=n;i++) { t=read(); ;j<=t;j++) { y=read(); ) add(i,y,); ); } } spfa(a); ; printf("%d",dis[b]); ; }
最新文章
- dbca建库sys用户被锁
- 使用SQL Server 2008 维护计划(图解)
- C# 系统错误日志处理类
- git 笔记1
- react-基础(2)
- 至强CPU性能排行,从X3210起,由低至高排列。
- LintCode Binary Tree Paths
- Java Hour 20 Spring
- Qt之图形视图框架
- bios作用
- ffmpeg, libav学习记录
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户
- 实现Android 动态载入APK(Fragment or Activity实现)
- unity3d教程动态创建简单平面地形
- centos安装docker容器
- PDO数据库操作类
- linux文件系統详解
- Leetcode1000 合并石头的最低成本 区间DP
- 什么是redis的雪崩和穿透
- 进入Linux单用户模式