201409-2-窗口

(http://115.28.138.223/view.page?gpid=T15)

#include <cstdio>  
#include <iostream>  
#include <algorithm>  
#include <cstring>  
using namespace std;  
typedef struct node
{  
    int x1,y1,x2,y2;  
}Node;  
Node node[32];                //窗口结构体数组  
int a[32];                    //保存各个窗口的上下关系  
int main()
{  
    //freopen("in.txt", "r", stdin);  
    int n,m,x,y;  
    while(scanf("%d%d",&n,&m)!=EOF)
    {  
        memset(a,0,sizeof(a));  
        memset(node,0,sizeof(node));  
        for(int i=1;i<=n;i++)  
            scanf("%d%d%d%d",&node[i].x1,&node[i].y1,&node[i].x2,&node[i].y2);  
        for(int i=1;i<=n;i++) a[i]=n-i+1;  
        for(int i=0;i<m;i++)
        {  
            scanf("%d%d",&x,&y);  
            int flag=0;  
            for(int j=1;j<=n;j++)
            {  
                int p=a[j];  
                if(x>=node[p].x1&&x<=node[p].x2&&y>=node[p].y1&&y<=node[p].y2)
                {   //如果点击的位置落在该窗口,如选中3  
                    //则5 4 3 2 1->5 4 2 1 3
                    printf("%d\n",p);  
                    flag=1;  
                    for(int k=j;k>=2;k--) a[k]=a[k-1];//调整各窗口相对上下位置  
                    a[1]=p;  
                    break;  
                }  
            }  
            if(!flag) puts("IGNORED");  
        }  
    }  
    return 0;  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值