试题编号: | 201409-2 |
试题名称: | 画图 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: | 问题描述 在一个定义了直角坐标系的纸上,画一个(x1,y1)到(x2,y2)的矩形指将横坐标范围从x1到x2,纵坐标范围从y1到y2之间的区域涂上颜色。 输入格式 输入的第一行包含一个整数n,表示要画的矩形的个数。 输出格式 输出一个整数,表示有多少个单位的面积被涂上颜色。 样例输入 2 样例输出 15 评测用例规模与约定 1<=n<=100,0<=横坐标、纵坐标<=100。 |
思路:借助二维数组,将坐标范围中的值全部++;则可不用判断哪些是重复的,最后只需要数一数哪些数组中的值大于0即可
#include<bits/stdc++.h>
#define _for(i,a,b) for(int i = (a);i < (b);i++)
using namespace std;
int A[105][105];
int main()
{
int n,sum = 0,x1,x2,y1,y2;
cin>>n;
for(int i = 0; i < n;i++)
{
cin>>x1>>y1>>x2>>y2;
for(int j = x1;j < x2;j++)
for(int k = y1;k < y2;k++)
{
A[j][k]++;
}
}
for(int i = 0;i < 105;i++)
{
for(int j = 0;j < 105;j++)
{
if(A[i][j] > 0)
sum++;
}
}
cout<<sum<<endl;
return 0;
}