HDU 4883 Best Coder Round 2 TIANKENG’s restaurant 解读
2015-06-26 12:35
579 查看
有一组数据是在客人到达和出发时间,问:多少把椅子的能力,以满足所有客人的需求,可以有一个地方坐下要求。
有些人甚至开始考虑暴力法,这些数据是少,其实这个问题很多数据, 暴力需求O(n*n)的时间效率,显然,将加班,因此,有必要O(n) 或O(nlgn)算法。
属于一道想透了就很easy的,可是没想过就会很困难的题目。
解法是:
把全部客人到来和离开的时间都排成序列。每次客人到来须要n张桌椅,那么就+上n,每次客人离开就会返还n张桌椅,那么就-去n,求这种最大值。
详细算法代码就那么几行,处理IO的代码都比这个长。
要想出来还真是十分困难。只是也算是经典算法了,应该学熟练。
有些人甚至开始考虑暴力法,这些数据是少,其实这个问题很多数据, 暴力需求O(n*n)的时间效率,显然,将加班,因此,有必要O(n) 或O(nlgn)算法。
属于一道想透了就很easy的,可是没想过就会很困难的题目。
解法是:
把全部客人到来和离开的时间都排成序列。每次客人到来须要n张桌椅,那么就+上n,每次客人离开就会返还n张桌椅,那么就-去n,求这种最大值。
详细算法代码就那么几行,处理IO的代码都比这个长。
要想出来还真是十分困难。只是也算是经典算法了,应该学熟练。
const int MAX_N = 10001; struct Interval { int t, wei; bool operator<(Interval const &i) const { if (t == i.t) return wei < i.wei; return t < i.t; } }; Interval inter[MAX_N<<1]; inline int timeToSec(int h, int m) { return h * 60 + m; } int main() { int T, n, h, m, w, num; scanf("%d", &T); while (T--) { scanf("%d", &n); num = 0; for (int i = 0; i < n; i++) { scanf("%d %d:%d", &w, &h, &m); inter[num].t = timeToSec(h, m); inter[num++].wei = w; scanf("%d:%d", &h, &m); inter[num].t = timeToSec(h, m); inter[num++].wei = -w; } sort(inter, inter+num); int ans = 0, tmp = 0; for (int i = 0; i < num; i++) { tmp += inter[i].wei; ans = max(tmp, ans); } printf("%d\n", ans); } return 0; }
相关文章推荐
- 设计模式--浅谈抽象工厂模式
- 希尔排序
- 黑马程序员——Java中的多线程
- magento 每日新品展示
- Android monkey 初步
- Nginx下Magento伪静态规则,适用于LNMP一键包
- Android M的App Links实现详解
- Two Sum-n方优化与C++map的使用
- URL 传+号到后台变空格问题解决方案
- android不是内部或外部命令,也不是可运行的程序或批处理文件
- View,Activity,Window三者的关系
- Android中的软件Watchdog
- 2015/06/26
- [SoapUI] 循环遍历某个Test Case下的所有Test Step,将Cookie传递给这些Test Step
- android studio debug
- Spring与Quartz的整合实现定时任务调度
- liunx下面新建一个文件然后上传到FTP
- 辅助方法
- Android调用系统功能获取当前经纬度
- 前端知识体系目录