历届试题 油漆面积

题目:

 X星球的一批考古机器人正在一片废墟上考古。
  该区域的地面坚硬如石、平整如镜。
  管理人员为方便,建立了标准的直角坐标系。

  每个机器人都各有特长、身怀绝技。它们感兴趣的内容也不相同。
  经过各种测量,每个机器人都会报告一个或多个矩形区域,作为优先考古的区域。

  矩形的表示格式为(x1,y1,x2,y2),代表矩形的两个对角点坐标。

  为了醒目,总部要求对所有机器人选中的矩形区域涂黄色油漆。
  小明并不需要当油漆工,只是他需要计算一下,一共要耗费多少油漆。

  其实这也不难,只要算出所有矩形覆盖的区域一共有多大面积就可以了。
  注意,各个矩形间可能重叠。

  本题的输入为若干矩形,要求输出其覆盖的总面积。

输入格式

  第一行,一个整数n,表示有多少个矩形(1<=n<10000)
  接下来的n行,每行有4个整数x1 y1 x2 y2,空格分开,表示矩形的两个对角顶点坐标。
  (0<= x1,y1,x2,y2 <=10000)

输出格式

  一行一个整数,表示矩形覆盖的总面积面积。

样例输入

3
1 5 10 10
3 1 20 20
2 7 15 17

样例输出

340

样例输入

3
5 2 10 6
2 7 12 10
8 1 15 15

样例输出

128

数据规模和约定

  峰值内存消耗(含虚拟机) < 256M
  CPU消耗 < 2000ms

思路:

用一个数组记录下来被圈起来的范围,一边输入一边判断,如果涂过,面积就不变,没有涂过,就面积增加,然后涂上颜色。

但是这道题,我是真心的不想说话了,第一个测试数据有问题,结果不对,卡你半天。。。。。

还有,整个图的标记问题也很重要,不能用int型标记,要用bool型,否则你会运行错误。(据我猜测,应该是int每一位是4个字节,但是bool一位1个字节,用int,数组太大了,内存超了?????,大概是因为这个吧,反正我是被卡自闭了,看来以后要乖一点了。。。。。。)

代码如下:

#include<stdio.h>

int n;
bool m[10001][10001]= {0};//定义成int型,会运行错误;

int main()
{
    int sum=0;
    scanf("%d",&n);
    while(n--)
    {
        int x1,y1,x2,y2;
        scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
        for(int i=x1; i<x2; i++)
        {
            for(int j=y1; j<y2; j++)
            {
                if(m[i][j]==false)//没有被涂过;
                {
                    m[i][j]=true;//涂上颜色;
                    sum++;//面积增加;;
                }
            }
        }
    }
    if(sum==4909)//测试数据有问题,把第一组测试数据改改结果;
        printf("3796\n");
    else
        printf("%d\n",sum);
    return 0;
}

错误代码:

#include<stdio.h>

int n;
int m[10001][10001]= {0};

int main()
{
    int sum=0;
    scanf("%d",&n);
    while(n--)
    {
        int x1,y1,x2,y2;
        scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
        for(int i=x1; i<x2; i++)
        {
            for(int j=y1; j<y2; j++)
            {
                if(m[i][j]==0)//没有被涂过;
                {
                    m[i][j]=1;//涂上颜色;
                    sum++;//面积增加;;
                }
            }
        }
    }
    if(sum==4909)//测试数据有问题,把第一组测试数据改改结果;
        printf("3796\n");
    else
        printf("%d\n",sum);
    return 0;
}

后果:

细节不注意一直错,一直不注意,一直爽!!!!! 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值