試題編号:201403-2
試題名稱:視窗
時間限制:1.0s
記憶體限制:256.0MB
問題描述
在某圖形作業系統中,有 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
#include<iostream>//每個結構體變量為一個視窗
#include<algorithm>
using namespace std;
const int maxx=3000;
int n,m,x,y;
struct node
{
int x1,y1,x2,y2;
int f;
int s;
}a[maxx];
bool cmd(const node &a,const node &b)
{
return a.f>b.f;
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)//f越大,越靠上
{
cin>>a[i].x1>>a[i].y1>>a[i].x2>>a[i].y2;
a[i].f=i;
a[i].s=i;
}
for(int i=1;i<=m;i++)
{
bool flag=0;
sort(a+1,a+n+1,cmd);
cin>>x>>y;
for(int j=1;j<=n;j++)
{
if(x>=a[j].x1&&x<=a[j].x2&&y>=a[j].y1&&y<=a[j].y2)
{
cout<<a[j].s<<endl;
a[j].f=n;
for(int k=1;k<=n;k++)
if(k==j)
continue;
else
a[k].f--;
flag=1;
break;
}
}
if(!flag)
cout<<"IGNORED"<<endl;
}
}