题目链接

http://acm.hdu.edu.cn/showproblem.php?pid=1050

题意为:

为了叙述方便,把一个房间里面的桌子移动到另一个房间称为一个移动,给出若干个要求完成的移动,任意两个移动仅在移动路线不相交的情况下可以同时进行,求出移动所需花费的最小次数(时间).

注意:

出现有"对门"的路线,不能同时移动,例如,[2,4]和[3,5]不能同时进行,因为3和4对门.

路线重叠:

凡是路线重叠的两个移动,不能同时进行.路线重叠例如,[1,4]和[2,5]路线重叠,[2,4]和[3,5]路线重叠,[4,2]和[5,3]路线重叠.根据题意,可以看出,移动的顺序对于路线是否重叠没有影响.另外,对门的位置可以看做一个位置.

思路:将每一条移动路线看做一条直线,假设所有的移动同时进行,则会有多个地方出现直线重叠的情况,求出重叠的最大层数(有多少条直线在同一处重叠最多)

C++代码如下

#include<iostream>
#include<algorithm>
using namespace std; int main()
{
int T;
cin >> T;//测试次数
int start,end;//每次移动的起始位置
while(T--)
{
int n;//每次测试中,移动的个数
cin >> n;
int a[200] = {0};//记录每个位置的重叠的次数,开始都为0.
//一共有400个房间,由于对门位置看做一个位置,所以共有200个位置.
for(int i=0;i<n;i++)//针对每个移动而言.
{
cin >> start >> end; start = (start+1)/2;
end = (end+1)/2;//这样处理之后,对门位置变为一个位置.可以把两个 + 同时改为 - 也正确. int max = std::max(start,end);//为了下面循环而作的处理
int min = std::min(start,end);
for(int k=min;k<=max;k++)//看看这个移动为200个位置上的重叠次数的贡献是多大.
a[k] ++;
}
int max = -1;
for(int i=0;i<200;i++)//找出数组a中最大值
{
if(a[i]>max)
{
max = a[i];
}
}
cout << 10*max << endl;
} return 0;
}

参考:

http://www.cnblogs.com/ahu-shu/p/3551829.html

【hdoj_1050】Moving Tables的更多相关文章

  1. 【POJ1083】 Moving Tables (并行的搬运)

    BUPT2017 wintertraining(15) #6E 题意 房间1和2,3和4,...,399和400共用一节走廊,有q次从房间li到ri的搬运桌子,一次搬运10分钟.两个搬运如果走廊有重叠 ...

  2. 【贪心】Moving Tables POJ 1083

    题目链接:http://poj.org/problem?id=1083 题目大意:走廊上的房间如下图设置,现在有n个移动桌子的任务,把桌子从xi移动到yi(整个过程中会占用xi到yi房间之间的走廊), ...

  3. 【01】markdown语法

    [02]段落和换行 一个 Markdown 段落是由一个或多个连续的文本行组成,它的前后要有一个以上的空行(空行的定义是显示上看起来像是空的,便会被视为空行.比方说,若某一行只包含空格和制表符,则该行 ...

  4. 【LeetCode】队列 queue(共8题)

    [346]Moving Average from Data Stream [353]Design Snake Game [363]Max Sum of Rectangle No Larger Than ...

  5. 【LeetCode】设计题 design(共38题)

    链接:https://leetcode.com/tag/design/ [146]LRU Cache [155]Min Stack [170]Two Sum III - Data structure ...

  6. hdoj 1050 Moving Tables【贪心区间覆盖】

    Moving Tables Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  7. 【整理】mysql中information_schema.tables字段说明

    [整理]mysql中information_schema.tables字段说明 2016-05-04 16:47:50|  分类: 默认分类|举报|字号 订阅     下载LOFTER我的照片书  | ...

  8. 【77.78%】【codeforces 625C】K-special Tables

    time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...

  9. 【Codeforces Round #423 (Div. 2) A】Restaurant Tables

    [Link]:http://codeforces.com/contest/828/problem/A [Description] 有n个组按照时间顺序来餐馆; 每个组由一个人或两个人组成; 每当有一个 ...

随机推荐

  1. org.json.Json Object的put和append方法比较

    json.append(key,value) 会把 value 包装成一个数组 JSONObject append = new JSONObject().append("a", & ...

  2. Source Tree基础教程2

    1.分支 项目——分支——推送 新分支要重新拉取项目后才可以看见 项目——拉取 2合并分支代码 将其他分支代码合并到当前分支——提交

  3. vue2.0介绍

    1.vue.js 是什么 vue(view)是一套构建用户界面的渐进式框架 Vue (pronounced /vjuː/, like view) is a progressive framework  ...

  4. powerdesigner 外键生成sql语句设置在创建表里面

    根据情况需要将创建外键表的sql语句生成在创建表的sql语句中,如下设置:

  5. 【python】python 中的三元表达式(三目运算符)

    python中的三目运算符不像其他语言其他的一般都是 判定条件?为真时的结果:为假时的结果 如 result=5>3?1:0 这个输出1,但没有什么意义,仅仅是一个例子.而在python中的格式 ...

  6. 黑群晖DSM 6.1网卡支持列表

    黑群晖DSM 6.1网卡支持列表 Network Drivers====================================AMDamd8111e : AMD 8111 (new PCI ...

  7. [洛谷P3203][HNOI2010]弹飞绵羊

    题目大意:有$n$个节点,第$i$个节点有一个弹力系数$k_i$,当到达第$i$个点时,会弹到第$i+k_i$个节点,若没有这个节点($i+k_i>n$)就会被弹飞.有两个操作: $x:$询问从 ...

  8. Codeforces Round #430 (Div. 2) Vitya and Strange Lesson

    D.Vitya and Strange Lesson(字典树) 题意: 给一个长度为\(n\)的非负整数序列,\(m\)次操作,每次先全局异或\(x\),再查询\(mex\) \(1<=n< ...

  9. Mysql History list length 值太大引起的问题

    1. 环境 Mysql 主从 Mysql版本:5.1.49-log 系统:Red Hat Enterprise Linux Server release 5.4  64bit 2. 表面现象 数据库操 ...

  10. 安卓titlebar的组合控件使用

    http://blog.csdn.net/itachi85/article/details/51435187