【题目链接】:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=3466

【题意】



有n个站台;(线性的);

每相邻两个站台之间的火车的行驶时间是固定的;

然后每天在第一个站台会向第n个站台的方向发出m1辆车;

最后一个站台会向第1个站台的方向发出m2辆车;

给出m1辆车是何时发出的,m2辆车是何时发出的(递增顺序给出);

然后有一个人要从1号站台,到n号站台;

且要求在T时刻会面;

可以在站台上等待;

问你它最少需要在站台上等待的时间;(在车上就不占时间);

【题解】



设dp[i][j]表示在第i时刻,在第j个站台所需的最短等待时间;

dp[0][1] = 0,dp[0][2..n]=INF;

在每一个站台有3种可能的决策

1.站在站台不动,时间递增1,站台不变;

2.搭上某一辆车;(向左或向右),时间不变,站台改变;

则有

dp[i][j]=dp[i−1][j]+1;

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

(如果在i−t[j]时刻,j+1站台有向左的车);

dp[i][j]=min(dp[i][j],dp[i−t[j−1]][j−1])

(如果在i−t[j]时刻,j−1站台有向右的车);

在何时在某一站有向左/向右的车可以在读时间的时候就预处理出来;

注意超过T就结束->注意break和continue;

这样DP数组的第一维最大为T,第二维最大为N

最后输出dp[T][n];

当然要判断一下是否有解



【Number Of WA】



3



【反思】



在break和continue的使用上竟然还会出现问题。

Case那个东西要记得输出。



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("F:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 50;
const int MAXT = 200;
const int INF = 0x3f3f3f3f; int n,T,t[N+10],has[200+10][N+10][2];
int m,dp[MAXT+10][N+10]; int main(){
//Open();
//Close();
int kk = 0;
while (~scanf("%d",&n)){
if (n==0) break;
kk++;
ms(has,0),ms(dp,INF);
scanf("%d",&T);
rep1(i,1,n-1)
scanf("%d",&t[i]);
scanf("%d",&m);
rep1(i,1,m){
int now;scanf("%d",&now);
if (now>T) continue;
has[now][1][0] = 1;
rep1(j,1,n-1){
now+=t[j];
if (now>T) break;
has[now][j+1][0] = 1;
}
}
scanf("%d",&m);
rep1(i,1,m){
int now;scanf("%d",&now);
if (now>T) continue;
has[now][n][1] = 1;
rep2(j,n-1,1){
now+=t[j];
if (now>T) break;
has[now][j][1] = 1;
}
}
dp[0][1] = 0;
rep1(i,2,n) dp[0][i] = INF;
rep1(i,1,T)
rep1(j,1,n){
dp[i][j] = dp[i-1][j] + 1;
if (j+1<=n && i-t[j]>=0 && has[i-t[j]][j+1][1]) // <-
dp[i][j] = min(dp[i][j],dp[i-t[j]][j+1]);
if (j-1>=1 && i-t[j-1]>=0 && has[i-t[j-1]][j-1][0]) // ->
dp[i][j] = min(dp[i][j],dp[i-t[j-1]][j-1]);
}
cout << "Case Number "<<kk<<": ";
if (dp[T][n]>=INF)
cout <<"impossible"<<endl;
else
cout << dp[T][n] << endl;
}
return 0;
}

【uva 1025】A Spy in the Metro的更多相关文章

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

    题意: 有线性的n个车站,从左到右编号分别为1~n.有M1辆车从第一站开始向右开,有M2辆车从第二站开始向左开.在0时刻主人公从第1站出发,要在T时刻回见车站n 的一个间谍(忽略主人公的换乘时间).输 ...

  2. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  3. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  4. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  5. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  6. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【BZOJ 1025】[SCOI2009]游戏

    [题目链接]:http://www.lydsy.com/JudgeOnline/problem.php?id=1025 [题意] [题解] 每一个对应关系,里面其实都会生成大小不一的几个环. 每一个环 ...

  9. 【Uva 11584】Partitioning by Palindromes

    [Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...

随机推荐

  1. Devexpress控件使用一:GridControl

    1.控件及列表展示 1).控件 2).构建表格,用于列表展示 3).gridControl绑定数据 4).调用绑定:BindDataSource(InitDt()); 5).展示列表 2.表格的列配置 ...

  2. 【BZOJ3678】Wangxz和OJ

    题意: 不想讲 题解: Rope真香! 正解是Splay缩点,访问时再拆成一个序列 代码: //STL dafa good! #include<algorithm> #include< ...

  3. 垃圾回收器(GC)

    值类型占用的空间在方法执行结束后会被马上释放, 引用类型占用的空间在方法结束后不会被马上释放,具体什么时间释放由垃圾回收器(GC)来决定. GC(Garbage Collection):JAVA/.N ...

  4. python_if_else,while,break

    #密码密文展示,getpass在pycharm中无法使用,只能在python中使用import getpass #登录判断'''raw_name="Monica"raw_passw ...

  5. win系统安装node出现这个2503和2502解决办法

    一: 今天在公司的新电脑要安装appium,所以要搭建appium的环境,所以在安装到node的时候,出现了内部错误2503和2502,安装中断. 这种错误可能是权限不足导致,一般“.exe”程序可以 ...

  6. asp.net C# 获取网页源代码的几种方式

    1 方法 System.Net.WebClient aWebClient = new System.Net.WebClient(); aWebClient.Encoding = System.Text ...

  7. swift学习笔记(五)构造过程

    构造过程是为了使用某个类.结构体或枚举类型的实例而进行的准备过程.在构造过程中,对每一个属性进行了初始值预设和其它必要的准备和初始化工作. 与OC相比,swift的构造函数.不须要返回值.同一时候,在 ...

  8. [LeetCode]Median of Two Sorted Arrays 二分查找两个有序数组的第k数(中位数)

    二分.情况讨论 因为数组有序,所以能够考虑用二分.通过二分剔除掉肯定不是第k位数的区间.如果数组A和B当前处理的下标各自是mid1和mid2.则 1.假设A[mid1]<B[mid2], ①.若 ...

  9. HDU1232 畅通project 并查集

    这道题跟HDU 1213 How Many Tables 并查集很接近,都是赤裸裸的并查集的题. 思路:如果还须要建n-1条路.每并一次就自减1. 參考代码: #include<stdio.h& ...

  10. centos7 配置redis

    文件上传 yum -y install lrzsz 安装redis部署前操作 同时下载redis-.tar.gz安装包 yum -y install gcc-c++ yum -y install tc ...