3958 火车进站

时间限制: 1 s
空间限制: 256000 KB
题目等级 : 大师 Master
 
 
 
 
题目描述 Description

火车站内往往设有一些主干线分叉出去的铁路支路,供火车停靠,以便上下客或装载货物。铁路支路有一定长度;火车也有一定的长度,且每列火车的长度相等。

假 设某东西向的铁路上,有一小站。该站只有一条铁路支路可供火车停靠,并且该铁路支路最多能容纳M 辆火车。为了火车行驶的通畅,该站只允许火车自东方进站,自西方出站,且先进站的火车必须先出站,否则,站内火车将发生堵塞。该火车站工作任务繁忙。每天 都有 N  辆自东方驶向西方的火车要求在预定时刻进站,并在站内作一定时间的停靠。

为了满足每辆进站火车的要求,小站的调度工作 是井井有条地开展。在小站每天的工作开始前,小站工作人员须阅读所有火车的进站申请,并决定究竞接受哪些火车的申请。而对于不能满足要求的火车,小站必须 提前通知它们,请它们改变行车路线,以免影响正常的铁路运输工作。由于火车进站、出站的用时可以忽略不计,小站允许几辆火车同时进站或出站,且小站工作人 员可以任意安排这些火车进站的先后排列次序。小站的工作原则是尽量地满足申请火车的要求。

请你编一个程序,帮助工作人员考察某天所有火车的进站申请,计算最多能满足多少火车的要求。

输入描述 Input Description

共N+1 行。

第一行是两个正整数N 和M。(N<=100,M<=3);

以下N 行每行是一辆火车的进站申请,第i+1 行的两个整数分别表示第i 列火车的进站的时间和火车出站的时间。

输出描述 Output Description

仅一行,是一个正整数B,表示火车站最多能接纳的火车数量。

样例输入 Sample Input

6 3

2 4

1 7

3 6

5 7

8 10

9 11

样例输出 Sample Output

5

数据范围及提示 Data Size & Hint

祝各位大牛早日AC

【题解】

分情况讨论。

m = 1时,dp[i]表示i在站台上的最大进站数。dp[i] = max{dp[j] + 1};

要求j在i之前进站且j在i进站前出站

m = 2时,dp[i][j]表示i和j正在站台上的最大进站数。dp[i][j] = max{dp[j][k] + 1};

要求k在j前进站,j在i前进站,且k在i进站前出站

m = 3时,dp[i][j][k]表示i,j,k正在站台上的最大进站数。dp[i][j][k] = max{dp[j][k][l] + 1};

要求k在j前进站,l在k前进站,j在i前进站,且l在i进站前出站

先按进站时间从小到大排序,为了无后效性,从小往大递推。为了判断进站时间相等的若干列车,

i,j,k,l均要从1..n。

50^4数据略大,因此当遇到第一个后面的车进站时间大于前面的车时直接break来减少常数

(实际上常数本来就很小,随便过)

 #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#define min(a, b) ((a) < (b) ? (a) : (b))
#define max(a, b) ((a) > (b) ? (a) : (b)) inline void read(int &x)
{
x = ;char ch = getchar(), c = ch;
while(ch < '' || ch > '')c = ch, ch = getchar();
while(ch <= '' && ch >= '')x = x * + ch - '', ch = getchar();
if(c == '-')x = -x;
} const int MAXN = + ; int dp1[MAXN], dp2[MAXN][MAXN], dp3[MAXN][MAXN][MAXN], n, m; struct Node
{
int reach, leave;
Node(int _reach, int _leave){reach = _reach, leave = _leave;}
Node(){}
}node[MAXN]; bool cmp(Node a, Node b)
{
return a.reach == b.reach ? a.leave < b.leave : a.reach < b.reach;
} int ans; int main()
{
read(n), read(m);
for(register int i = ;i <= n;++ i) read(node[i].reach), read(node[i].leave);
std::sort(node + , node + + n, cmp);
if(m == )
{
ans = min(n, );
for(register int i = ;i <= n;++ i)
{
dp1[i] = ;
for(register int j = ;j <= n;++ j)
{
if(node[j].reach > node[i].reach)break;
if(i == j || node[j].leave > node[i].reach)continue;
dp1[i] = max(dp1[i], dp1[j] + );
}
ans = max(ans, dp1[i]);
} }
else if(m == )
{
ans = min(, n);
for(register int i = ;i <= n;++ i)
for(register int j = ;j <= n;++ j)
{
if(node[i].reach < node[j].reach)break;
if(i == j || node[i].leave < node[j].leave)continue;
dp2[i][j] = ;
for(register int k = ;k <= n;++ k)
{
if(node[k].reach > node[j].reach)break;
if(j == k || i == k || node[k].leave > node[i].reach || node[k].leave > node[j].leave)continue;
dp2[i][j] = max(dp2[i][j], dp2[j][k] + );
}
ans = max(ans, dp2[i][j]);
}
}
else
{
ans = min(n, );
for(register int i = ;i <= n;++ i)
for(register int j = ;j <= n;++ j)
{
if(node[j].reach > node[i].reach)break;
if(i == j || node[i].leave < node[j].leave)continue;
for(register int k = ;k <= n;++ k)
{
if(node[k].reach > node[j].reach)break;
if(j == k || i == k || node[j].leave < node[k].leave)continue;
dp3[i][j][k] = ;
for(register int l = ;l <= n;++ l)
{
if(node[l].reach > node[k].reach )break;
if(l == k || l == i || j == l|| node[l].leave > node[i].reach || node[l].leave > node[k].leave)continue;
dp3[i][j][k] = max(dp3[i][j][k], dp3[j][k][l] + );
}
ans = max(ans, dp3[i][j][k]);
}
}
}
printf("%d", ans);
return ;
}

CodeVS 3958火车进站

CodeVS3958 火车进站的更多相关文章

  1. 华为OJ:火车进站

    火车进站 给定一个正整数N代表火车数量,0<N<10,接下来输入火车入站的序列,一共N辆火车,每辆火车以数字1-9编号.要求以字典序排序输出火车出站的序列号. 输入描述: 有多组测试用例, ...

  2. (hdu)1022 Train Problem I 火车进站问题

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1022 Problem Description As the new term comes, ...

  3. C++ HOJ 火车进站

    [问题描写叙述] 给定一个正整数N代表火车数量.0<N<10,接下来输入火车入站的序列,一共N辆火车,每辆火车以数字1-9编号. 要求以字典序排序输出火车出站的序列号. 输入:   有多组 ...

  4. HDU 1022 火车进站【栈】

     题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1022 题目大意: 题目大概意思:有N辆火车,以序列1方式进站,判断是否能以序列2方式出栈.进站不一定 ...

  5. 华为OJ—火车进站(栈,字典排序)

    http://career-oj.huawei.com/exam/ShowSolution?method=SolutionApp&id=2282 给定一个正整数N代表火车数量,0<N&l ...

  6. poj 1363 火车进站 (栈的应用)

    Description There is a famous railway station in PopPush City. Country there is incredibly hilly. Th ...

  7. 火车进站输出路径(HDU1022)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1022 解题报告: 思路: 就是维护好这个栈,只要它不是空,并且头部和ans相同,就一直出栈,直到不满足 ...

  8. 火车安排问题(dp好题)

    火车站内往往设有一些主干线分叉出去的铁路支路,供火车停靠,以便上下客或装载货物.铁路 支路有一定长度:火车也有一定的长度,且每列火车的长度相等. 假设某东西向的铁路上,有一小站.该站只有一条铁路支路可 ...

  9. HDU 1022(火车过站 栈)

    题意是给定火车进站的序列和出站的序列,问能否完成转换,若能输出过程. 和另一道以火车进站为背景的栈应用题类似,但增加了对于过程的输出,只需要多记录一下进出站顺序即可. #include <bit ...

随机推荐

  1. 使用 SourceTree 操作时弹出 password required

    通过 https 的方式克隆仓库的,SourceTree 推送等操作的时候会弹出提示要求输入密码. 在仓库里面设置: 远程仓库-选中仓库-点击编辑-修改 url 路径, 路径格式,以码云为例: htt ...

  2. Excel常用函数总结

    Excel常用函数总结 2016-10-28 Kevin 叼着奶瓶撩妹 1. VLOOKUP函数 常见形式 问题描述:将下图中G列的数据根据学生的姓名填充到D列. 公式解析: =VLOOKUP(A2, ...

  3. 深入浅出 Java Concurrency (24): 并发容器 part 9 双向队列集合 Deque[转]

    有一段时间没有更新了.接着上节继续吧. Queue除了前面介绍的实现外,还有一种双向的Queue实现Deque.这种队列允许在队列头和尾部进行入队出队操作,因此在功能上比Queue显然要更复杂.下图描 ...

  4. PAT甲级——A1099 Build A Binary Search Tree

    A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...

  5. <jsp:forward page=""></jsp:forward>标签失效异常

    解决方案:在web.xml <filter-mapping>          <filter-name>struts2</filter-name>         ...

  6. MySQL Server Logs

    日志记录存储方式 #日志记录存储方式 mysql> show variables like 'log_output'; mysql> set global log_output='FILE ...

  7. 推荐5款超实用的.NET性能分析工具

    虽然.NET框架号称永远不会发生内存泄漏,原因是引入了内存回收机制.但在实际应用中,往往我们分配了对象但没有释放指向该对象的引用,导致对象永远无法释放.最常见的情况就是给对象添加了事件处理函数,但当不 ...

  8. 主成分分析(PCA)原理详解_转载

    一.PCA简介 1. 相关背景 在许多领域的研究与应用中,往往需要对反映事物的多个变量进行大量的观测,收集大量数据以便进行分析寻找规律.多变量大样本无疑会为研究和应用提供了丰富的信息,但也在一定程度上 ...

  9. 查找IE中网页的源代码

    一般我们在查看网页的源代码时,在网页上右键就能点击“查看源代码”.但是有些网页的右键功能被屏蔽了.这时候我们可以在ie菜单栏的“查看”选项里“源”查找. 如果发现ie菜单没在的话,点击键盘上的“Alt ...

  10. Android SDK上手指南:示例项目

    Android SDK上手指南:示例项目 2013-12-26 15:40 核子可乐译 51CTO 字号:T | T Android SDK示例项目中的应用能够执行种种功能,例如各类用户界面元素.数据 ...