ccf 201403-2 視窗(100分)
問題描述
在某圖形作業系統中,有 N 個視窗,每個視窗都是一個兩邊與座標軸分別平行的矩形區域。視窗的邊界上的點也屬於該視窗。視窗之間有層次的區別,在多於一個視窗重疊的區域裡,只會顯示位於頂層的窗口裡的內容。
當你點選螢幕上一個點的時候,你就選擇了處於被點選位置的最頂層視窗,並且這個視窗就會被移到所有視窗的最頂層,而剩餘的視窗的層次順序不變。如果你點選的位置不屬於任何視窗,則系統會忽略你這次點選。
現在我們希望你寫一個程式模擬點選視窗的過程。
輸入格式
輸入的第一行有兩個正整數,即 N 和 M。(1 ≤ N ≤ 10,1 ≤ M ≤ 10)
接下來 N 行按照從最下層到最頂層的順序給出 N 個視窗的位置。 每行包含四個非負整數 x1, y1, x2, y2,表示該視窗的一對頂點座標分別為 (x1, y1) 和 (x2, y2)。保證 x1 < x2,y1 2。
接下來 M 行每行包含兩個非負整數 x, y,表示一次滑鼠點選的座標。
題目中涉及到的所有點和矩形的頂點的 x, y 座標分別不超過 2559 和 1439。
輸出格式
輸出包括 M 行,每一行表示一次滑鼠點選的結果。如果該次滑鼠點選選擇了一個視窗,則輸出這個視窗的編號(視窗按照輸入中的順序從 1 編號到 N);如果沒有,則輸出"IGNORED"(不含雙引號)。
樣例輸入
3 4
0 0 4 4
1 1 5 5
2 2 6 6
1 1
0 0
4 4
0 5
樣例輸出
2
1
1
IGNORED
樣例說明
第一次點選的位置同時屬於第 1 和第 2 個視窗,但是由於第 2 個視窗在上面,它被選擇並且被置於頂層。
第二次點選的位置只屬於第 1 個視窗,因此該次點選選擇了此視窗並將其置於頂層。現在的三個視窗的層次關係與初始狀態恰好相反了。
第三次點選的位置同時屬於三個視窗的範圍,但是由於現在第 1 個視窗處於頂層,它被選擇。
最後點選的 (0, 5) 不屬於任何視窗。
依照題目模擬即可,具體過程見程式碼及註釋,提交後得100分的C++程式如下:
#include<iostream> #include<algorithm> #include<cmath> using namespace std; struct windows { int x1, y1, x2, y2; }w[15]; int order[15]; int main() { int n, m; cin >> n >> m; int n1 = n; for (int i = 1; i <= n; i++) order[i] = n1--;//視窗的初始順序 for (int i = 1; i <= n; i++) { cin >> w[i].x1 >> w[i].y1 >> w[i].x2 >> w[i].y2; } int cx, cy;//點選的位置 while (m--) { int flag = 0;//是否被點選 cin >> cx >> cy; for (int i = 1; i <= n; i++) { if (w[order[i]].x1 <= cx&&w[order[i]].x2 >= cx&&w[order[i]].y1 <= cy&&w[order[i]].y2 >= cy) { flag = 1; int no1 = order[i]; cout <<no1<< endl; for (int j = i; j >=2; j--) order[j] = order[j - 1];//調整順序 order[1] =no1; break; } } if (!flag) cout << "IGNORED" << endl; } return 0; }