POJ1083 Moving Tables
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 35297 | Accepted: 11774 |
Description

The floor has 200 rooms each on the north side and south side along the corridor. Recently the Company made a plan to reform its system. The reform includes moving a lot of tables between rooms. Because the corridor is narrow and all the tables are big, only one table can pass through the corridor. Some plan is needed to make the moving efficient. The manager figured out the following plan: Moving a table from a room to another room can be done within 10 minutes. When moving a table from room i to room j, the part of the corridor between the front of room i and the front of room j is used. So, during each 10 minutes, several moving between two rooms not sharing the same part of the corridor will be done simultaneously. To make it clear the manager illustrated the possible cases and impossible cases of simultaneous moving.

For each room, at most one table will be either moved in or moved out. Now, the manager seeks out a method to minimize the time to move all the tables. Your job is to write a program to solve the manager's problem.
Input
Each of the following N lines contains two positive integers s and t, representing that a table is to move from room number s to room number t each room number appears at most once in the N lines). From the 3 + N -rd
line, the remaining test cases are listed in the same manner as above.
Output
Sample Input
3
4
10 20
30 40
50 60
70 80
2
1 3
2 200
3
10 100
20 80
30 50
Sample Output
10
20
30
Source
酒店有400个房间,如下编号对称分布在一条走廊两侧
1 3 5 ... 397 399
这里是走廊
2 4 6 ... 398 400
现在要从房间s->t搬桌子,有N组房间需要搬桌子,每搬一次10分钟(不论两个房间相隔多远).
对于某组房间,搬桌子期间 s->t 之间的走廊会被占用,
而其他组房间若没有使用到占用的走廊,则可同时搬,否则要等待.
特别地,相对的两间房,共用一段走廊, 即若房间3的走廊被占用了,等同于房间4的走廊被占用了.
给定N组需要搬的桌子,求最小可以搬完的时间.
解题思路:
感觉这题有点类似于多线程的同步互斥场景问题.
① 由于相对的两间房共用同一段走廊,为了方便处理问题,可以把所有奇数房间转换成偶数房间,反之亦可.
如 1->6 可等价转换成 2->6, 尔后只需要关注一侧的房间即可(共200间)
② 根据房间号对走廊进行分割,可分割成200段走廊. 在从房间s->t搬桌子期间,对所使用到的每段走廊计数+1
③ 所有桌子搬完后,统计每段走廊的计数值(计数值代表这段走廊总共需要被占用的次数),
由于题目并不考虑搬动期间的移动过程因素(类比多线程的事务锁),
因此最大的一个计数值*10分钟 就是所求的最小搬完时间(因为只要走廊被占着,就只能在下一次再搬,不能同时搬)
#include <iostream>
using namespace std; const static int ROOM_NUM = ; // 最大房号
const static int TIME_UNIT = ; // 时间单位 /*
* 把偶数房号转换成奇数房号
* even 偶数房号
* return 奇数房号
*/
int toOdd(int even); void solve(void); int main(void) {
int testCase = ;
cin >> testCase;
for(int t = ; t < testCase; t++) {
solve();
} //system("pause");
return ;
} int toOdd(int even) {
return (even % == ? even - : even);
} void solve(void) {
int useCnt[ROOM_NUM] = { }; // 每个房间前的走廊被使用的次数
int maxUseCnt = ; // 被使用最多的次数 int moveCnt = ; // 需要搬动的桌子组数
cin >> moveCnt;
int* fromRooms = new int[moveCnt]; // 起点房间集
int* toRooms = new int[moveCnt]; // 终点房间集
for(int i = ; i < moveCnt; i++) {
int from, to;
cin >> from >> to; // 使房号小的在前面
fromRooms[i] = (from <= to ? from : to);
toRooms[i] = (from > to ? from : to); // 把房号全部转换成奇数
fromRooms[i] = toOdd(fromRooms[i]);
toRooms[i] = toOdd(toRooms[i]); // 相关房间前占用的走廊被使用次数+1
for(int roomId = fromRooms[i]; roomId <= toRooms[i]; roomId += ) {
useCnt[roomId]++;
if(maxUseCnt < useCnt[roomId]) {
maxUseCnt = useCnt[roomId]; // 登记最大的使用次数
}
}
}
delete[] fromRooms;
delete[] toRooms; // 计算最小的使用时间
maxUseCnt = (maxUseCnt <= || maxUseCnt > moveCnt ? moveCnt : maxUseCnt);
int minUsedTime = maxUseCnt * TIME_UNIT;
cout << minUsedTime << endl;
}
POJ1083 Moving Tables的更多相关文章
- POJ1083 Moving Tables(模拟)
The famous ACM (Advanced Computer Maker) Company has rented a floor of a building whose shape is in ...
- 解题报告:poj1083 Moving tables
2017-09-02 19:49:59 writer:pprp 题意说明: 比较简单的题,一开始被吓到了,后来才发现,其实可以用很简单的方法就可以解决: 就是在这样的房间中如果在i 和 j 中之后的1 ...
- POJ1083(Moving Tables)--简单模拟
题目链接:http://poj.org/problem?id=1083 如图所示在一条走廊的两侧各有200个房间,现在给定一些成对的房间相互交换桌子,但是走廊每次只能通过一组搬运, 也就是说如果两个搬 ...
- Moving Tables(贪心或Dp POJ1083)
Moving Tables Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 28304 Accepted: 9446 De ...
- zstu.2512. Moving Tables(贪心)
Moving Tables Time Limit: 1 Sec Memory Limit: 64 MB Submit: 1182 Solved: 563 Description The famo ...
- HDOJ 1050 Moving Tables
Moving Tables Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- 1050 Moving Tables
Moving Tables Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- Moving Tables
Moving Tables Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total ...
- hdoj 1050 Moving Tables【贪心区间覆盖】
Moving Tables Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
随机推荐
- DPDK- program_guide 2
Data Plane Development Kit(DPDK) RTE_SDK and RTE_TARGET must be configured. ~EAL ~librte_mempool ~li ...
- vue生命周期图片
- HDU - 5833: Zhu and 772002 (高斯消元-自由元)
pro:给定N个数Xi(Xi<1e18),保证每个数的素因子小于2e3:问有多少种方案,选处一些数,使得数的乘积是完全平方数.求答案%1e9+7: N<300; sol:小于2e3的素数只 ...
- JavaScript 之 预编译 作用域,作用域链
第一次写博客,本来是学习jQuery遇到闭包问题,发现并没有理解闭包,发现闭包牵扯的知识点太多.复习了一遍(发现自己该记住的全忘了)写在博客里,自己也是小白,希望大神们指点迷津,必将感激不尽. 我们知 ...
- APNs
生成推送证书: 1. 登陆开发者中心:https://developer.apple.com2. 点开 certificates.identifiers 和 proversionprofiles 里面 ...
- laravel 修改时邮箱字段唯一性验证时忽略指定 ID
- Python基础:五、Python程序的编写方式
python程序有两种编写方式: 1. 进入cmd控制台(linux终端),输入python进入编辑模式,这时候我们可以直接编写python程序 2. 也可以在.py文件中编写python代码,通过p ...
- https://www.cnblogs.com/yudanqu/p/9467803.html
https://www.cnblogs.com/yudanqu/p/9467803.html
- 动画讲解TCP的3次握手,4次挥手
https://mp.weixin.qq.com/s/TUBhH_lJe6M4KgAZO-rP2A TCP三次握手和四次挥手的问题在面试中是最为常见的考点之一.很多读者都知道三次和四次,但是如果问深入 ...
- 测试CentOS-7-x86_64-Minimal-1708.iso这种光盘安装效果
在dvd1光盘安装选择mininal时有292个包 [root@localhost ~]# rpm -qa|wc -l 292 [root@localhost ~]# 测试下使用mininal的iso ...