A Spy in the Metro(UVA 1025 ACM/ICPC World Finals2003)

---恢复内容开始---

题意:有n(2<=n<=50)个车站,从左到右编号为1~n,有M1辆列车从第1站向右开,还有M2辆列车从第N站向左开。在时刻0,间谍从第1站出发,目的是在时刻T(0<=T<=200)会见在车站n的一个间谍。在车站等候容易被抓,所以需要尽量躲在火车上,使在车站等待的时间尽量的少,列车靠站时间忽略不计,即使2站方向相反列车在同一时间靠站,间谍也能完成换乘。

题解:由于时间有序,所以可以通过判断在时刻t,在车站i 最少需要等候多少时间进行DP。由于输入较2复杂,所以可以用has_train数组表示在时刻t,车站i是否有向左或者向右的火车。具体细节可见代码。

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;

const int maxn = 50 + 5;
const int maxt = 200 + 5;
const int INF = 1000000000;
int t[maxn],has_train[maxt][maxn][2],dp[maxt][maxn];

int main(){
    int n,T,m1,m2,kase=0;
    while(~scanf("%d",&n)&&n){
        scanf("%d",&T);
        for(int i=1;i<n;i++){
            scanf("%d",&t[i]);///i到i+1的时间
        }
        memset(has_train, 0, sizeof(has_train));
        scanf("%d",&m1);int d;
        for(int i=0;i<m1;i++){
                scanf("%d",&d);
        for(int j=1; j<n; j++) {///此处从1开始表示车站数
                if(d<=T) has_train[d][j][0] = true;///d为时间,i为车站,表示在时间d时是否有向右的车可以搭乘
                d+=t[j];
                }
        }
        scanf("%d",&m2);
        for(int i=0;i<m2;i++){
            scanf("%d",&d);
            for(int j=n-1;j>0;j--){
                if(d<=T) has_train[d][j+1][1]=true;///d为时间,i为车站,表示在时间d时是否有向左的车可以搭乘
                d+=t[j];
            }
        }
        for(int i=1;i<n;i++) dp[T][i]=INF;///最终点不会在第n站之外
        dp[T][n]=0;
        for(int i=T-1;i>=0;i--)///逆序倒推,对于每个车站都有3个选择,等待1个单位时间,搭乘向右的车,搭乘向左的车
        for(int j=1;j<=n;j++){///对于每个单位时间,找出这个单位时间中在所有车站中的最优解
            dp[i][j]=dp[i+1][j]+1;
            if(j<n&&has_train[i][j][0]&&i+t[j]<=T)
                dp[i][j]=min(dp[i][j],dp[i+t[j]][j+1]);///向右搭乘的选择比较,时间加上达到下一个车站的时间,车站向右移动
            if(j>1&&has_train[i][j][1]&&i+t[j-1]<=T)
                dp[i][j]=min(dp[i][j],dp[i+t[j-1]][j-1]);///对3种状态进行查询,找出最优解
        }

        printf("Case Number %d: ",++kase);
        if(dp[0][1]>=INF) printf("impossible\n");
        else
            printf("%d\n",dp[0][1]);
    }
    return 0;
}
时间: 2024-10-11 10:59:24

A Spy in the Metro(UVA 1025 ACM/ICPC World Finals2003)的相关文章

A Spy in the Metro UVA - 1025

题意:某城市的地铁是线性的,有n(2<=n<=50)个车站,从左到右的编号为1~n.有M1辆车从第1站出发往右开,还有M2辆车从第n站开始往左开. 在时刻0,Mario从第1站出发,目的是在时刻T(0<=T<=200)会见车站n的一个间谍.在车站等车时容易被抓,所以她决定躲在开动的火车上,让在 车站等待的总时间尽量短.列车靠站停车时间忽略不计,且Mario身手敏捷,即使两辆方向不同的列车在同一时间靠站,Mario也能完成换乘. 题解:时间是单向流逝的,是一个天然的序.影响到决策的只

UVA 1025 A Spy in the Metro(DP)

Secret agent Maria was sent to Algorithms City to carry out an especially dangerous mission. After several thrilling events we find her in the first station of Algorithms City Metro, examining the time table. The Algorithms City Metro consists of a s

UVA 1025 - A Spy in the Metro (DAG的动态规划)

第一遍,刘汝佳提示+题解:回头再看!!! POINT: dp[time][sta]; 在time时刻在车站sta还需要最少等待多长时间: 终点的状态很确定必然是的 dp[T][N] = 0 ---即在T时刻的时候正好达到N站点 我们可以 从终点的状态往起始的状态转化, 一步步走就可以了. has_train[t][i][0]; t时刻在i车站是否有往右开的火车 has_train[t][i][1]; t时刻在i车站是否有往左开的火车 #include <iostream>#include &l

UVA 1025 A Spy in the Metro

A Spy in the Metro #include <iostream> #include <cstdio> #include <cstring> using namespace std; int INF=0x3f3f3f3f; int kase=0; int main() { int n; while(scanf("%d",&n)&&n!=0) { int T,M1,M2,time[n+1]; scanf("%

UVA 1025 A Spy in the Metro DP

DP[ i ][ j ] 在 i 时刻 j 号车站的等待最小时间..... 有3种可能: 在原地等,坐开往左边的车,做开往右边的车 A Spy in the Metro Time Limit: 3000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Submit Status Description Secret agent Maria was sent to Algorithms City to carry out an es

UVA 1025 A Spy in the Metro(DAG dp)

UVA 1025 1 #include<cstdio> 2 #include<iostream> 3 #include<queue> 4 #include<vector> 5 #include<stack> 6 #include<set> 7 #include<string> 8 #include<cstring> 9 #include<math.h> 10 #include<algorith

洛谷2583 地铁间谍 (UVa1025A Spy in the Metro)

洛谷2583 地铁间谍(UVa1025A Spy in the Metro) 本题地址:http://www.luogu.org/problem/show?pid=2583 题目描述 特工玛利亚被送到S市执行一个特别危险的任务.她需要利用地铁完成他的任务,S市的地铁只有一条线路运行,所以并不复杂. 玛利亚有一个任务,现在的时间为0,她要从第一个站出发,并在最后一站的间谍碰头.玛利亚知道有一个强大的组织正在追踪她,她知道如果一直呆在一个车 站,她会有很大的被抓的风险,躲在运行的列车中是比较安全的.

《ACM/ICPC 算法训练教程》读书笔记一之数据结构(堆)

书籍简评:<ACM/ICPC 算法训练教程>这本书是余立功主编的,代码来自南京理工大学ACM集训队代码库,所以小编看过之后发现确实很实用,适合集训的时候刷题啊~~,当时是听了集训队final的意见买的,感觉还是不错滴. 相对于其他ACM书籍来说,当然如书名所言,这是一本算法训练书,有着大量的算法实战题目和代码,尽管小编还是发现了些许错误= =,有部分注释的语序习惯也有点不太合我的胃口.实战题目较多是比较水的题,但也正因此才能帮助不少新手入门,个人认为还是一本不错的算法书,当然自学还是需要下不少

2014 ACM/ICPC Asia Regional Guangzhou Online Wang Xifeng&#39;s Little Plot HDU5024

一道好枚举+模拟题目.转换思维视角 这道题是我做的,规模不大N<=100,以为正常DFS搜索,于是傻乎乎的写了起来.各种条件限制模拟过程 但仔细一分析发现对每个点进行全部八个方向的遍历100X100X100^8 .100X100个点,每个点在走的时候8中选择,TLE 于是改为另一个角度: 以符合要求的点为拐弯点,朝两个垂直的方向走,求出最远的距离.这样只要对每个点各个方向的长度知道,组合一下对应的就OK. 避免了每个点深搜. PS:搜索的时候x,y写反了,导致构图出现问题,以后用[dy][dx]