天天看點

CSP:視窗

試題編号: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;
  }
}