XDOJ窗口模拟(详解版)

先放题:

标题	
窗口模拟

类别	
综合

时间限制	
2S

内存限制	
256Kb

问题描述	
在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标轴分别平行的矩形区域。窗口的边界上的点也属于该窗口。
窗口之间有层次的区别,在多于一个窗口重叠的区域里,只会显示位于顶层的窗口里的内容。
当你点击屏幕上一个点的时候,你就选择了处于被点击位置的最顶层窗口,并且这个窗口就会被移到所有窗口的最顶层,而剩余的窗口的层次顺序不变。
如果你点击的位置不属于任何窗口,则系统会忽略你这次点击。
现在我们希望你写一个程序模拟点击窗口的过程。

输入说明	
输入的第一行有两个正整数,即 N 和 M。(1 ≤ N ≤ 10,1 ≤ M ≤ 50)
接下来 N 行按照从最下层到最顶层的顺序给出 N 个窗口的位置。 每行包含四个非负整数 x1, y1, x2, y2,表示该窗口的一对顶点坐标分别为 (x1, y1) 和 (x2, y2)。保证 x1 < x2,y1 < y2。
接下来 M 行,每行包含两个非负整数 x, y,表示一次鼠标点击的坐标。
题目中涉及到的所有点和矩形的顶点的 x, y 坐标分别不超过1280 和1024。

输出说明	
输出包括 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) 不属于任何窗口。

其实这题真不难,有愧于我大西电四星题了。

最开始我的思路就是

三个数组,一个放窗口,一个放指令(点击位置),一个标记窗口位置

再从最顶层开始找,找到输出位置,并且将该层置顶,否则ignored

实际上也很顺利的写出来了

放上代码(详解在里面了)

#include<stdio.h>

void zhiding(int N[10][4],int location[10], int j,int n)
{ //由于刚入坑,想不到什么简单的方法,有的话还请大佬指点一下
	int i, k,a,b[10][4];
	a = location[j];
	b[j][0] = N[j][0]; b[j][1] = N[j][1]; b[j][2] = N[j][2]; b[j][3] = N[j][3];
	for (i = 0; i < n-1; i++)
	{
		if (i >= j)//下一层覆盖上一层
		{
			N[i][0] = N[i + 1][0]; N[i][1] = N[i + 1][1]; N[i][2] = N[i + 1][2]; N[i][3] = N[i + 1][3];//为了美观放到一行了
			location[i] = location[i + 1];
		}
	}
	N[n - 1][0] = b[j][0]; N[n - 1][1] = b[j][1]; N[n - 1][2] = b[j][2]; N[n - 1][3] = b[j][3]; 
	location[n - 1] = a; //放到最后一层
}

int main()
{
	int n, m;
	int N[10][4] = { 0 }, M[50][2] = { 0 },location[10];
	int i, j,k=1;
	scanf("%d%d", &n, &m);

	for (i = 0; i < n; i++)    //窗口输入
	{
			scanf("%d%d%d%d", &N[i][0],&N[i][1], &N[i][2], &N[i][3]);  //可以双层for循环,至于我为什么没用(doge)
	    	location[i] = k++;//标记窗口为第几个窗口
	}

	for (i = 0; i < m; i++)    //点击输入
	{
			scanf("%d%d", &M[i][0],&M[i][1]);  //同上
	}

	for (i = 0; i < m; i++)//每个指令遍历
	{
		int t = 0; //标记变量,找到了窗口就为一,否则为零,先重置为零
		for (j = n - 1; j >= 0; j--)//从顶层开始遍历
		{
			if (M[i][0] >= N[j][0] && M[i][0] <= N[j][2] && M[i][1] >= N[j][1] && M[i][1] <= N[j][3])
			{
				t = 1;
				printf("%d\n", location[j]);
				if (j != n - 1)//如果是顶层就不用变动,否则置于顶层
					zhiding(N, location, j, n);//将该层置于顶层
				break;//记得跳出
			}
		}	
		if(t==0)//t为0,不在任意窗口里
		printf("IGNORED\n");
	}
	return 0;
}

附上成绩

 纯小白,有问题还请大佬指正,

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值