矩形

大东林 acm 题源

description

在测试超大规模集成电路时,对给定的一个设计,专家要检测元件是否相互遮盖。一个元件可视为一个矩形,假设每个矩形都是水平排列的(边与x轴或y轴平行),所以长方形由最小的和最大的x,y坐标表示。
编程计算完全被覆盖的矩形个数。

							

input

输入有多组长方形实例。对每组长方形,第一个数字是长方形的数量,然后是长方形的最小和最大x,y坐标(最小x,最大x,最小y,最大y)。
							

output

对每组输入数据,输出一行,是被完全覆盖的长方形数量。
							

sample_input

3
100 101 100 101
0 3 0 101
20 40 10 400
4
10 20 10 20
10 20 10 20
10 20 10 20
10 20 10 20

							

sample_output

0
4
#include <iostream>
#include <cstdio>
using namespace std;
const int N =222222;
struct{
int minx,miny;
int maxx,maxy;
}a[N];
int main()
{
int n,sum;

    while(scanf("%d\n",&n)!=EOF)
    {

       for(int i=0;i<n;i++)
        scanf("%d%d%d%d",&a[i].minx,&a[i].maxx,&a[i].miny,&a[i].maxy);
       sum=0;
       for(int i=0;i<n;i++)//枚举所有矩形。
        for(int j=0;j<n;j++)//再枚举所有可能包裹它的矩形。
       {
           if(j!=i&&a[i].minx>=a[j].minx&&a[i].maxx<=a[j].maxx&&a[i].miny>=a[j].miny&&a[i].maxy<=a[i].maxy)//a[i]这个矩形被包裹了。
           {
                sum++;//计数加一。
                break;//可以退出了,不然重复计算。
           }
       }
       printf("%d\n",sum);
    }
    return 0;
}

也可以不用结构体类似于方法二:
#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
int main()
{
    int i,n,minx[1005],miny[1005],maxx[1005],maxy[1005];
    while(~scanf("%d",&n))
    {
        int sum=0;
        for(i=0;i<n;i++)
            scanf("%d%d%d%d",&minx[i],&maxx[i],&miny[i],&maxy[i]);
        for(i=0;i<n;i++)
            for(int j=0;j<n;j++)
                if(j!=i&&minx[j]<=minx[i]&&maxx[j]>=maxx[i]&&miny[j]<=miny[i]&&maxy[j]>=maxy[i])
                {
                    sum++;
                    break;
                }
        printf("%d\n",sum);
    }
    return 0;
}


你可能感兴趣的:(矩形)