【题目链接】: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. JS异步操作之promise发送短信验证码.html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta cont ...

  2. ModelDriven机制及其运用

    ModelDriven 为什么需要ModelDriven 所谓ModelDriven ,意思是直接把实体类当成页面数据的收集对象.比如,有实体类User 如下: package cn.com.lead ...

  3. mybatis批量插入、批量更新和批量删除

    转载 https://www.jianshu.com/p/041bec8ae6d3

  4. lua中调用C++函数

    lua中调用C++函数 我们产品中提供了很多lua-C API给用户在lua中调用,之前一直没用深究其实现原理,只是根据已有的代码在编码.显然这不是一个好的习惯,没用达到知其所以然的目的. 一.基本原 ...

  5. swift语言点评二十-扩展

    结论:扩展无法修改原来的数据结构. Extensions can add new functionality to a type, but they cannot override existing ...

  6. RocketMQ学习笔记(7)----RocketMQ的整体架构

    1. RocketMQ主要的9个模块,如图: 2. 模块介绍 1. rocketmq-common:通用的常量枚举,基类方法或者数据结构,按描述的目标来分包,通俗易懂.报名有admin,consume ...

  7. 我的Java历程_写出这个数

    lzJava基础进行中,今天偶然间看到的一个题目: 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字.如下代码: import java.util.*;public class Ma ...

  8. redis搭建与安装

    redis提供五种数据类型:string,hash,list,set及zset(sorted set). 第一部分:安装redis 希望将redis安装到此目录 1 /usr/local/redis ...

  9. caioj 1153 扩展欧几里德算法(解不定方程)

    模板题 注意exgcd函数要稍微记一下 #include<cstdio> #include<cctype> #include<algorithm> #define ...

  10. 总结使人进步,可视化界面GUI应用开发总结:Android、iOS、Web、Swing、Windows开发等

    可视化界面的软件,是21世纪最主流的应用类型了,黑屏控制台的不适合普通用户.   2004年左右的时候,作为普通网民,接触的自然是可视化,准确是Windows那一套.   那个时候,Microsoft ...