CCF認證考試(java)---視窗
問題描述
試題編號: 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
樣例說明
第一次點選的位置同時屬於第 1 和第 2 個視窗,但是由於第 2 個視窗在上面,它被選擇並且被置於頂層。
第二次點選的位置只屬於第 1 個視窗,因此該次點選選擇了此視窗並將其置於頂層。現在的三個視窗的層次關係與初始狀態恰好相反了。
第三次點選的位置同時屬於三個視窗的範圍,但是由於現在第 1 個視窗處於頂層,它被選擇。
最後點選的 (0, 5) 不屬於任何視窗。
解答
這道題非常簡單,判斷是否在視窗內,只需要滿足X1<=x<=X2,Y1<=y<=Y2就可以了。至於滿足點選後的視窗置頂這個條件,我的程式碼使用連結串列(list)作為裝載視窗的資料結構,所以點選這個視窗後,先把這個視窗add到連結串列的最後,然後remove掉這個節點就可以啦
package test;
import java.util.ArrayList;
import java.util.Scanner;
public class Main2014032 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in=new Scanner(System.in);
int N=in.nextInt();
int M=in.nextInt();
ArrayList<window> list=new ArrayList<window>();
for(int i=0;i<N;i++){
list.add(new window(in.nextInt(),in.nextInt(), in.nextInt(),in.nextInt(),i+1));
}
int x0=0,y0=0;
String out[]=new String [M];
int k;
for(int j=0;j<M;j++){
x0=in.nextInt();
y0=in.nextInt();
k=N-1;
for(;k>=0;k--){
if(list.get(k).check(x0, y0)!=0){
out[j]=list.get(k).check(x0, y0)+"";
//System.out.println(out[j]);
window temp=null;
list.add(list.get(k));
list.remove(k);
break;
}
}
if(k<0) out[j]="IGNORED";
}
for(int l=0;l<M;l++){
System.out.println(out[l]);
}
//System.out.println(new window(0, 0, 2, 2,1).check(1, 1));
}
static class window{
int x1,x2,y1,y2;
int order;
public window(int x1,int y1,int x2,int y2,int order){
this.x1=x1;this.y1=y1;
this.x2=x2;this.y2=y2;
this.order=order;
}
public int check(int x0,int y0){
if(x0>=x1 && x0<=x2 && y0>=y1 && y0<=y2){
return order;
}else{
return 0;
}
}
}
}