1. 程式人生 > >CCF認證考試(java)---視窗

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; } } } }