栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

poj 1394 Railroad

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

poj 1394 Railroad

#include<stdio.h>#include<string.h>#include<iostream>using namespace std;#define INF 1000001int C, T;struct {int time;int city;}map[1000][100];char name[100][100];int start, dist;int train[1000];int travel[100];int search(char *city) {for(int i=0; i<C; i++) {if(!strcmp(name[i], city))return i;}return -1;}void solve(int dep) {int i, j, k;for(i=0; i<C; i++) {travel[i] = INF;}travel[start] = dep;for(k=0; k<C; k++) {for(i=0; i<T; i++) {for(j=0; j<train[i]-1; j++) {if(map[i][j].time >= travel[map[i][j].city] && travel[map[i][j+1].city] > map[i][j+1].time)travel[map[i][j+1].city] = map[i][j+1].time;}}}for(i=0; i<C; i++) {if(i != dist)travel[i] = -1;}for(k=0; k<C; k++) {for(i=0; i<T; i++) {for(j=0; j<train[i]-1; j++) {if(map[i][j+1].time <= travel[map[i][j+1].city] && travel[map[i][j].city] < map[i][j].time)travel[map[i][j].city] = map[i][j].time;}}}}int main() {int i, j;char str[1000];int dep;int id = 1;while(scanf("%d", &C), C) {for(i=0; i<C; i++)scanf("%s", name[i]);scanf("%d", &T);for(i=0; i<T; i++) {scanf("%d", &train[i]);for(j=0; j<train[i]; j++) {scanf("%d%s", &map[i][j].time, str);map[i][j].city = search(str);}}scanf("%d", &dep);scanf("%s", str);start = search(str);scanf("%s", str);dist = search(str);solve(dep);printf("Scenario #%dn", id++);if(travel[dist] < INF) {printf("Departure %.4d %sn", travel[start], name[start]);printf("Arrival   %.4d %snn", travel[dist], name[dist]);} else {puts("No connectionn");}}return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/377731.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号