poj 1394 Railroad

來源:互聯網
上載者:User

http://acm.poj.org/problem?id=1394

求儘可能遲的出發,但又最早到的火車路線

#include<stdio.h><br />#include<string.h><br />#define INF 1000001<br />int C, T;<br />struct {<br />int time;<br />int city;<br />}map[1000][100];<br />char name[100][100];<br />int start, dist;<br />int train[1000];<br />int travel[100];<br />int search(char *city) {<br />for(int i=0; i<C; i++) {<br />if(!strcmp(name[i], city))<br />return i;<br />}<br />return -1;<br />}<br />void solve(int dep) {<br />int i, j, k;<br />for(i=0; i<C; i++) {<br />travel[i] = INF;<br />}<br />travel[start] = dep;<br />for(k=0; k<C; k++) {<br />for(i=0; i<T; i++) {<br />for(j=0; j<train[i]-1; j++) {<br />if(map[i][j].time >= travel[map[i][j].city] && travel[map[i][j+1].city] > map[i][j+1].time)<br />travel[map[i][j+1].city] = map[i][j+1].time;<br />}<br />}<br />}<br />for(i=0; i<C; i++) {<br />if(i != dist)<br />travel[i] = -1;<br />}<br />for(k=0; k<C; k++) {<br />for(i=0; i<T; i++) {<br />for(j=0; j<train[i]-1; j++) {<br />if(map[i][j+1].time <= travel[map[i][j+1].city] && travel[map[i][j].city] < map[i][j].time)<br />travel[map[i][j].city] = map[i][j].time;<br />}<br />}<br />}<br />}<br />int main() {<br />//freopen("in.txt", "r", stdin);<br />int i, j;<br />char str[1000];<br />int dep;<br />int id = 1;<br />while(scanf("%d", &C), C) {<br />for(i=0; i<C; i++)<br />scanf("%s", name[i]);<br />scanf("%d", &T);<br />for(i=0; i<T; i++) {<br />scanf("%d", &train[i]);<br />for(j=0; j<train[i]; j++) {<br />scanf("%d%s", &map[i][j].time, str);<br />map[i][j].city = search(str);<br />}<br />}<br />scanf("%d", &dep);<br />scanf("%s", str);<br />start = search(str);<br />scanf("%s", str);<br />dist = search(str);<br />solve(dep);<br />printf("Scenario #%d/n", id++);<br />if(travel[dist] < INF) {<br />printf("Departure %.4d %s/n", travel[start], name[start]);<br />printf("Arrival %.4d %s/n/n", travel[dist], name[dist]);<br />} else {<br />puts("No connection/n");<br />}<br />}<br />return 0;<br />} 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.