USACO 1.2 挤牛奶
Description
三個(gè)農(nóng)民每天清晨5點(diǎn)起床,然后去牛棚給3頭牛擠奶。第一個(gè)農(nóng)民在300時(shí)刻(從5點(diǎn)開始計(jì)時(shí),秒為單位)給他的牛擠奶,一直到1000時(shí)刻。第二個(gè)農(nóng)民在700時(shí)刻開始,在 1200時(shí)刻結(jié)束。第三個(gè)農(nóng)民在1500時(shí)刻開始2100時(shí)刻結(jié)束。期間最長(zhǎng)的至少有一個(gè)農(nóng)民在擠奶的連續(xù)時(shí)間為900秒(從300時(shí)刻到1200時(shí)刻),而最長(zhǎng)的無(wú)人擠奶的連續(xù)時(shí)間(從擠奶開始一直到擠奶結(jié)束)為300秒(從1200時(shí)刻到1500時(shí)刻)。
你的任務(wù)是編一個(gè)程序,讀入一個(gè)有N個(gè)農(nóng)民(1 <= N <= 5000)擠N頭牛的工作時(shí)間列表,計(jì)算以下兩點(diǎn)(均以秒為單位):
? 最長(zhǎng)至少有一人在擠奶的時(shí)間段。
? 最長(zhǎng)的無(wú)人擠奶的時(shí)間段。
Input
Line 1: 一個(gè)整數(shù)N。
Lines 2…N+1: 每行兩個(gè)小于1000000的非負(fù)整數(shù),表示一個(gè)農(nóng)民的開始時(shí)刻與結(jié)束時(shí)刻。
Output
一行,兩個(gè)整數(shù),即題目所要求的兩個(gè)答案。
Sample Input
3
300 1000
700 1200
1500 2100
Sample Output
900 300
.
.
.
.
.
.
分析
離散化(我打的真的是離散嗎?)
每一段時(shí)間都可以看成一條線段
將開頭和結(jié)尾映射到數(shù)軸上
在數(shù)軸上從左到右掃描
對(duì)于一個(gè)點(diǎn),如果它在某一條線段上,則累加
(注意,對(duì)于時(shí)間的間隔,它只可能存在于兩點(diǎn)之間)
.
.
.
.
.
程序:(代碼丑陋,請(qǐng)別介意)
轉(zhuǎn)載于:https://www.cnblogs.com/YYC-0304/p/10292812.html
總結(jié)
以上是生活随笔為你收集整理的USACO 1.2 挤牛奶的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 母亲的牛奶 Mother's Milk
- 下一篇: 线段树(假)练习题一(学校OJ的题)