【USACO题库】1.2.1 Milking Cows挤牛奶
2016-08-15 14:07
621 查看
题目描述
三个农民每天清晨5点起床,然后去牛棚给3头牛挤奶。第一个农民在300时刻(从5点开始计时,秒为单位)给他的牛挤奶,一直到1000时刻。第二个农民在700时刻开始,在 1200时刻结束。第三个农民在1500时刻开始2100时刻结束。期间最长的至少有一个农民在挤奶的连续时间为900秒(从300时刻到1200时刻),而最长的无人挤奶的连续时间(从挤奶开始一直到挤奶结束)为300秒(从1200时刻到1500时刻
你的任务是编一个程序,读入一个有N个农民(1 <= N <= 5000)挤N头牛的工作时间列表,计算以下两点(均以秒为单位):
最长至少有一人在挤奶的时间段。
最长的无人挤奶的时间段。
输入
Line 1:
一个整数N。
Lines 2..N+1:
每行两个小于1000000的非负整数,表示一个农民的开始时刻与结束时刻。
输出
一行,两个整数,即题目所要求的两个答案。
样例输入
3
300 1000
700 1200
1500 2100
样例输出
900 300
这题坑啊。。。
这道题我们先以开始时刻为第一关键字从小到大,以结束时刻为第二关键字从大到小快排。
之后定两个变量b1和e1,表示经过排序后第一个时间段的开始时间和结束时间,再定max1和max2,表示最长有人的时间段和最长无人的时间段,把max1设定为第一个时间段(即e1-b1)
之后我们依次枚举剩下的时间段。
例如这是样例:
刚开始b1为300,e1为1000。
之后我们与下一个时间段比较,发现它们可以合为一个时间段。
于是e1变成了1200。
再和第三条时间段比较,发现它们中间有时间空隙,不能合为一条时间段。
于是我们就先计算一下当前的时间长度是否比两个max大。
max1初始为300,而现在的时间段长度为(1200-300)=900,所以max1变为900;
而max2初始为0,现在的时间段长度为(1500-1200)=300,所以max2变为300。
然后把b1和e1变为第三条时间段的开始时间和结束时间(即1500和2100)。
最后再计算一下最后一段的长度,
max1为900,而(2100-1500)=600,所以我们不用更新。
最后max1为900,而max2为300,就是样例的答案。
其它的数据也是这样算。
三个农民每天清晨5点起床,然后去牛棚给3头牛挤奶。第一个农民在300时刻(从5点开始计时,秒为单位)给他的牛挤奶,一直到1000时刻。第二个农民在700时刻开始,在 1200时刻结束。第三个农民在1500时刻开始2100时刻结束。期间最长的至少有一个农民在挤奶的连续时间为900秒(从300时刻到1200时刻),而最长的无人挤奶的连续时间(从挤奶开始一直到挤奶结束)为300秒(从1200时刻到1500时刻
你的任务是编一个程序,读入一个有N个农民(1 <= N <= 5000)挤N头牛的工作时间列表,计算以下两点(均以秒为单位):
最长至少有一人在挤奶的时间段。
最长的无人挤奶的时间段。
输入
Line 1:
一个整数N。
Lines 2..N+1:
每行两个小于1000000的非负整数,表示一个农民的开始时刻与结束时刻。
输出
一行,两个整数,即题目所要求的两个答案。
样例输入
3
300 1000
700 1200
1500 2100
样例输出
900 300
这题坑啊。。。
这道题我们先以开始时刻为第一关键字从小到大,以结束时刻为第二关键字从大到小快排。
之后定两个变量b1和e1,表示经过排序后第一个时间段的开始时间和结束时间,再定max1和max2,表示最长有人的时间段和最长无人的时间段,把max1设定为第一个时间段(即e1-b1)
之后我们依次枚举剩下的时间段。
例如这是样例:
刚开始b1为300,e1为1000。
之后我们与下一个时间段比较,发现它们可以合为一个时间段。
于是e1变成了1200。
再和第三条时间段比较,发现它们中间有时间空隙,不能合为一条时间段。
于是我们就先计算一下当前的时间长度是否比两个max大。
max1初始为300,而现在的时间段长度为(1200-300)=900,所以max1变为900;
而max2初始为0,现在的时间段长度为(1500-1200)=300,所以max2变为300。
然后把b1和e1变为第三条时间段的开始时间和结束时间(即1500和2100)。
最后再计算一下最后一段的长度,
max1为900,而(2100-1500)=600,所以我们不用更新。
最后max1为900,而max2为300,就是样例的答案。
其它的数据也是这样算。
相关文章推荐
- 【USACO题库】1.2.1 Milking Cows挤牛奶
- 一大堆的福利之【USACO题库】 Milking Cows挤牛奶
- 1031. 【USACO题库】2.3.3 Zero Sum和为零
- 【USACO题库】5.3.4 Big Barn巨大的牛棚
- 【USACO题库】2.3.5 Controlling Companies控制公司
- 【USACO题库】3.3.3 Camelot亚瑟王的宫殿
- 【USACO题库】1.1.3 Friday the Thirteenth黑色星期五
- 【USACO题库】2.1.2 Ordered Fractions顺序的分数.tj
- 【USACO题库】3.4.2 American Heritage美国血统
- 一大堆的福利之【USACO题库】Greedy Gift Givers贪婪的礼物送礼者
- JZOJ1282.【USACO题库】3.2.1 Factorials阶乘
- JZOJ1315.【USACO题库】5.2.1 Snail Trails蜗牛的旅行
- 【USACO题库】【并查集】3.1.1 Agri-Net最短网络
- 【USACO题库】1.2.2 Transformations方块转换
- 【USACO题库】2.4.2 Overfencing穿越栅栏
- 【USACO题库】4.1.3 Fence Loops篱笆回路
- USACO 1.2.1 - MIlking Cows(模拟)
- 一大堆的福利之【USACO题库】Friday the Thirteenth黑色星期五
- usaco1.2.1 解题报告
- 【USACO题库】2.3.3 Zero Sum和为零