題目背景
漢東省政法大學附屬中學所在的光明區最近實施了名為「智慧型光明」的智慧型城市專案。具體到交通領域,通過「智慧型光明」終端,可以看到光明區所有紅綠燈此時此刻的狀態。小明的學校也安裝了「智慧型光明」終端,小明想利用這個終端給出的資訊,估算自己放學回到家的時間。
問題描述
一次放學的時候,小明已經規劃好了自己回家的路線,並且能夠**經過各個路段的時間。同時,小明通過學校裡安裝的「智慧型光明」終端,看到了出發時刻路上經過的所有紅綠燈的指示狀態。請幫忙計算小明此次回家所需要的時間。
輸入格式
輸入的第一行包含空格分隔的三個正整數 r、y、g,表示紅綠燈的設定。這三個數均不超過 106。
輸入的第二行包含乙個正整數 n,表示小明總共經過的道路段數和路過的紅綠燈數目。
接下來的 n 行,每行包含空格分隔的兩個整數 k、t。k=0 表示經過了一段道路,將會耗時 t 秒,此處 t 不超過 106;k=1、2、3 時,分別表示出發時刻,此處的紅綠燈狀態是紅燈、黃燈、綠燈,且倒計時顯示牌上顯示的數字是 t,此處 t 分別不會超過 r、y、g。
輸出格式
輸出乙個數字,表示此次小明放學回家所用的時間。
樣例輸入
30 3 30
80 10
1 50 11
2 20 6
0 33 10
0 3
樣例輸出46
樣例說明
小明先經過第一段路,用時 10 秒。第一盞紅綠燈出發時是紅燈,還剩 5 秒;小明到達路口時,這個紅綠燈已經變為綠燈,不用等待直接通過。接下來經過第二段路,用時 11 秒。第二盞紅綠燈出發時是黃燈,還剩兩秒;小明到達路口時,這個紅綠燈已經變為紅燈,還剩 11 秒。接下來經過第
三、第四段路,用時 9 秒。第三盞紅綠燈出發時是綠燈,還剩 10 秒;小明到達路口時,這個紅綠燈已經變為紅燈,還剩兩秒。接下來經過最後一段路,用時 3 秒。共計 10+11+11+9+2+3 = 46 秒。
評測用例規模與約定
有些測試點具有特殊的性質:
* 前 2 個測試點中不存在任何訊號燈。
測試點的輸入資料規模:
* 前 6 個測試點保證 n ≤ 103。
* 所有測試點保證 n ≤ 105
分析:本題只是稍微修改了下上一題變數的意義,解決起來便複雜了不少。
思路一:直接多重巢狀的if else,不僅**冗長,花太多時間,而且消耗太多腦力,更重要的是,邊界一不留神就出錯了,或者樣例過了但是得分很低。我小心翼翼的不停分類討論,if else多次巢狀,60行左右**過了樣例卻只有30分,至今還沒想明白**出了問題。所以ccf**越簡單越好,利於除錯而且不容易扣分。
思路二:簡化一下問題,紅黃綠三種狀態,綠燈行,其他狀態等待。我們可以將紅綠黃不斷迴圈的思路簡化為從綠到非綠的迴圈,這樣就變成了兩種狀態,解決起來**量少了一半,思維量也少了好幾倍。
稍微解釋下**:
k為2-黃燈轉化為k為1,t = t + r的狀態。還有兩個問題需要注意:其一是邊界,某時刻紅變綠,可以走,綠變黃瞬間,不可以走,在**中體現為判斷條件有沒有等號;其二是兩種狀態迴圈時,m < t時狀態不改變,而且轉一圈回來還可能回到原來的狀態,這時注意判斷需要等待的時間是多少。
#include using namespace std;
typedef long long ll;
int main()
if(k == 2) t += r;
int m = ans % (r + y + g);
if(k == 3)
} else
if(m >= t + g)
} }cout
}
CCF 201812 2 小明放學
題目大意 這題和第一題的區別在於,小明事先得知路況 路口通過時間和交通燈資料 走之前 估算走多少時間,不再是第一題那樣走多少記多少。思路 由於沒有親自去走,所以需要模擬人去走,得到走的總時間,遇到路口就加時間,遇到交通燈的時候,通過總時間和交通燈在出發時的情況,推算出現在交通燈情況,用現在的交通燈情...
CCF 201812 2小明放學
試題編號 201812 2 試題名稱 小明放學 時間限制 1.0s 記憶體限制 512.0mb 問題描述 題目背景 漢東省政法大學附屬中學所在的光明區最近實施了名為 智慧型光明 的智慧型城市專案。具體到交通領域,通過 智慧型光明 終端,可以看到光明區所有紅綠燈此時此刻的狀態。小明的學校也安裝了 智慧...
ccf201812 2小明放學
試題編號 201812 2 試題名稱 小明放學 時間限制 1.0s 記憶體限制 512.0mb 問題描述 題目背景 漢東省政法大學附屬中學所在的光明區最近實施了名為 智慧型光明 的智慧型城市專案。具體到交通領域,通過 智慧型光明 終端,可以看到光明區所有紅綠燈此時此刻的狀態。小明的學校也安裝了 智慧...