uva 1025,城市的间谍

题目链接:https://uva.onlinejudge.org/external/10/1025.pdf

题意:

地铁是线性的,有n个站,编号(1~n),M1辆从左至右的车,和M2辆从右至左的车,发车时刻给出,然后是,每两个站之间要跑多长时间。一个间谍要从1车站到n车站,但是他要求等车的时间最短,不然间谍会被抓,有可能到不了,输出impossible.

分析:

影响每一步的决策只有两个因素,1,时刻,2,哪一个车站。那么DP状态就出来了DP[T][n]在T时刻,第n个站还要等多少分钟。

状态转移:只有三个情况,要么是等一分钟,要么是上左边的车,要么是上右边的车。

边界条件dp[T][n] = 0;不用等了。

dp[i][j] = min(dp[i+1][j]+1,dp[i+t[j]][j+1],dp[i+t[j-1]][j-1]);

然后就是求has_train[][][2]数组了。具体看程序。

#include <bits/stdc++.h>

using namespace std;

#define INF 0x3f3f3f3f

int n;
int T;
int t[55];

int has_train[205][55][2];
int dp[205][55];

int main()
{
    int cases = 1;
    while(scanf("%d",&n),n)
    {
        scanf("%d",&T);
        for(int i=1; i<=n-1; i++)
        {
            scanf("%d",&t[i]);
        }

        int m1,m2;
        scanf("%d",&m1);
        memset(has_train,0,sizeof(has_train));

        while(m1--)
        {
            int d;
            scanf("%d",&d);
            for(int j=1; j<=n-1; j++)
            {
                if(d<=T) has_train[d][j][0] = 1;
                d+=t[j];
            }
        }

        scanf("%d",&m2);

        while(m2--) {
            int d;
            scanf("%d",&d);
            for(int j=n-1;j>=1;j--) {
                if(d<=T) has_train[d][j+1][1] = 1;
                d+=t[j];
            }
        }

        for(int i=1; i<=n-1; i++)
            dp[T][i] = INF;
        dp[T][n] = 0;

        for(int i = T-1; i>=0; i--)
        {
            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]);
                }

            }
        }

        printf("Case Number %d: ",cases++);
        if(dp[0][1]>=INF) printf("impossible\n");
        else printf("%d\n",dp[0][1]);

    }

    return 0;
}

时间: 2024-07-29 13:48:04

uva 1025,城市的间谍的相关文章

UVa 1025 城市里的间谍

https://vjudge.net/problem/UVA-1025 题意:一个间谍要从第一个车站到第n个车站去会见另一个,在是期间有n个车站,有来回的车站,让你在时间T内时到达n,并且等车时间最短,输出最短等车时间. 思路:先用一个has_train[t][i][0]来表示在t时刻,在车站i,是否有往右开的车.同理,has_train[t][i][1]用来保存是否有往左开的车. 用d(i,j)表示时刻i,你在车站j,最少还需要等待多长时间.边界条件是d(T,n)=0,其他d(T,i)为正无穷

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 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

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(动态规划)

传送门 Description 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

Uva 1025

题意: 某城市地铁是线性得,有n个车站,从左到右编号为1至n.有M1辆列车从第1站开始往右开,有M2辆列车从第n站开始往左开.在时刻0,Mario从第1站出发,目的是在时刻T会见车站n得一个间谍.在车站等车时容易被抓,所以她决定尽量躲在开动的火车上,让在车站等待的总时间尽量短.列车靠站停车时间忽略不计,并且Mario身手敏捷,即使两辆方向不同的列车在同一时间靠站,Mario也能完成换乘. 分析: 状态:d[i][j]代表时刻i,在车站j,最少的等待时间.边界情况d[T][n]=0,其余的d[T]

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

题意: 有线性的n个车站,从左到右编号分别为1~n.有M1辆车从第一站开始向右开,有M2辆车从第二站开始向左开.在0时刻主人公从第1站出发,要在T时刻回见车站n 的一个间谍(忽略主人公的换乘时间).输出最少的等待时间,如果无解输出impossible. 分析: d(i, j)表示第i时刻在第j个车站,最少还需要的等待时间.边界是:d(T, n) = 0, d(T, i) = +∞ 预处理: has_train[t][i][0]数组是用来记录t时刻第i个车站是否有向右开的车,类似has_train

UVa 1025 A Spy in the Metro (DP动态规划)

题意:一个间谍要从第一个车站到第n个车站去会见另一个,在是期间有n个车站,有来回的车站,让你在时间T内时到达n,并且等车时间最短, 也就是尽量多坐车,最后输出最少等待时间. 析:这个挺复杂,首先时间是一个顺序,设d(i,j)表示时刻 i 在第 j 个车站,最少还要等待多长时间,那么边界是d(T, n) = 0. 并且有三种决策: 决策一:等着 d[i][j] = d[i + 1][j] + 1; 为什么从i + 1 过来呢? 你想一下,DP表示等待的时间,那么是不是应该倒着来呢? 决策二:有往右