题目大意:

给定n行m列的黑白棋盘如下

给定矩形的左下点x1 y1和右上点x2 y2将这个区域都涂成白色

再给定矩形的左下点x3 y3和右上点x4 y4将这个区域都涂成黑色

求最后棋盘内有分别多少个白格和黑格

本来不怎么想发CF赛时AC的题 但是这题比较特别就想发一下~

为什么特别呢? 因为去年寒假集训的时候 有一道求多个矩形并的面积大小的题oj21547overplanting

当时学了一个矩形切割的方法 后来再也没有遇到什么类似的题

而今天 没错就是今天 终于撞上了hhh (虽然因为不熟悉 赛时小心翼翼地码 用了不少时间

好了说正题

首先因为是黑白相间的棋盘格 那么对于一个已知长宽的矩形 (长宽可由左下和右上的位置得到)

格数偶数则黑白格各半 若为奇数则多出的一个的颜色必为左下角那一格的颜色

那么怎么知道左下角的一格(设其位置为(i,j))是什么颜色呢

因为黑白相间的特性 只要判断一下 (i+j)%2 就行 为1黑色 为0则是白色

此时我们可以得到初始的棋盘有 W 个白格 和 B 个黑格

而涂色时 由于黑色是后涂的 所以我们可以直接计算被涂为黑色的格数

因为给定了涂色的左下和右上位置 我们可以用上面的方法求出这个矩形的黑格个数b和白格个数w

此时将这个矩形涂为黑色 对 W 和 B 的影响 就是 B+=w , W-=w ; ( 即把白格涂为黑色就够了 )

(那么将一个矩形涂为白色也同理  B+=b , W-=b ; )

而白色可能会被黑色覆盖 就是说白色的部分会被黑色所切割

那么我们只要把多出的部分割出来涂为白色就可以了 我们来画个图

骗人的~ 不放图了 看代码把很好懂

#include <bits/stdc++.h>
#define LL long long
using namespace std; LL n,m,B,W;
LL X1,Y1,X2,Y2,X3,Y3,X4,Y4;
void col(LL lx,LL ly,LL rx,LL ry,bool flag) {
LL N=ry-ly+1LL, M=rx-lx+1LL, b, w; if((lx+ly)%2LL) // 最左下一格为黑色
w=N*M/2LL, b=w+(N*M%2LL);
else // 否则为白色
b=N*M/2LL, w=b+(N*M%2LL); if(flag) W+=b, B-=b; // 涂白
else B+=w, W-=w; // 涂黑
}
void cut(LL lx,LL ly,LL rx,LL ry) {
if(lx>rx || ly>ry) return; // 矩形不合法
if(rx<X3 || ry<Y3 || lx>X4 || ly>Y4) {
col(lx,ly,rx,ry,); return;
} // 当前矩形不会被黑色部分切割到 直接涂为白色
if(lx<X3) cut(lx,ly,X3-1LL,ry), lx=X3;
if(rx>X4) cut(X4+1LL,ly,rx,ry), rx=X4;
if(ly<Y3) cut(lx,ly,rx,Y3-1LL), ly=Y3;
if(ry>Y4) cut(lx,Y4+1LL,rx,ry), ry=Y4;
}
int main()
{
int t; scanf("%d",&t);
while(t--) {
scanf("%I64d%I64d",&n,&m);
B=n*m/2LL, W=B+(n*m%2LL);
scanf("%I64d%I64d%I64d%I64d",&X1,&Y1,&X2,&Y2);
scanf("%I64d%I64d%I64d%I64d",&X3,&Y3,&X4,&Y4);
cut(X1,Y1,X2,Y2);
col(X3,Y3,X4,Y4,);
printf("%I64d %I64d\n",W,B);
} return ;
}

codeforces round#524 C. Masha and two friends /// 矩形切割的更多相关文章

  1. Codeforces Round #524 (Div. 2)(前三题题解)

    这场比赛手速场+数学场,像我这样读题都读不大懂的蒟蒻表示呵呵呵. 第四题搞了半天,大概想出来了,但来不及(中途家里网炸了)查错,于是我交了两次丢了100分.幸亏这次没有掉rating. 比赛传送门:h ...

  2. Codeforces Round #524 (Div. 2) C. Masha and two friends(矩形相交)

    C. Masha and two friends time limit per test 1 second memory limit per test 256 megabytes input stan ...

  3. Codeforces Round #524 (Div. 2) C. Masha and two friends

    C. Masha and two friends 题目链接:https://codeforc.es/contest/1080/problem/C 题意: 给出一个黑白相间的n*m的矩阵,现在先对一个子 ...

  4. Codeforces Round #524 (Div. 2) C. Masha and two friends(思维+计算几何?)

    传送门 https://www.cnblogs.com/violet-acmer/p/10146350.html 题意: 有一块 n*m 的棋盘,初始,黑白块相间排列,且左下角为白块. 给出两个区间[ ...

  5. Codeforces Round #524 (Div. 2) C. Masha and two friends 几何:判断矩形是否相交以及相交矩形坐标

    题意 :给出一个初始的黑白相间的棋盘  有两个人  第一个人先用白色染一块矩形区域 第二个人再用黑色染一块矩形区域 问最后黑白格子各有多少个 思路:这题的关键在于求相交的矩形区间 给出一个矩形的左下和 ...

  6. Codeforces Round #524 (Div. 2) C. Masha and two friends 思路

    题目:题目链接 思路:直接计数显然是不好处理的,但分情况讨论只要不写错这题是一定可以出的,但这样基本做完这个题就没时间做其他题了,但当时我就这么蠢的这样做了,比赛一个半小时的时候突然发现一个似乎可行的 ...

  7. Codeforces Round #524 (Div. 2) Masha and two friends矩形

    题目 题意:    给一个n*m块大的黑白相间的矩形,在这个举行中操作,要先把第一个矩形(左下角坐标(x1,y2),右上角坐标(x2,y2)) 全部涂成白色,再把第二个矩形(左下角坐标(x3,y3), ...

  8. Codeforces Round #524 (Div. 2) F. Katya and Segments Sets(主席树)

    https://codeforces.com/contest/1080/problem/F 题意 有k个区间,区间的种类有n种,有m个询问(n,m<=1e5,k<=3e5),每次询问a,b ...

  9. Codeforces Round #524 (Div. 2) E. Sonya and Matrix Beauty(字符串哈希,马拉车)

    https://codeforces.com/contest/1080/problem/E 题意 有一个n*m(<=250)的字符矩阵,对于每个子矩阵的每一行可以任意交换字符的顺序,使得每一行每 ...

随机推荐

  1. 使用linkedhashmap实现LRU(最近最少使用缓存算法)

    import java.util.LinkedHashMap; import java.util.Map; public class LRUCache<K, V> extends Link ...

  2. PHP简单读取XML

    DOM document object model,文档对象模型,就是树形结构 节点的分类 元素节点 属性节点 值节点 注释节点 根节点(document才是根节点) 生成XML文档 xml的根节点为 ...

  3. GDI及Windows的消息机制

    什么是GDI? GDI, Graphics Device Interface GDI在以下位置已经被微软列为Legacy Graphics,不建议使用来开发应用程序(http://msdn.micro ...

  4. PAT_A1048#Find Coins

    Source: PAT A1048 Find Coins (25 分) Description: Eva loves to collect coins from all over the univer ...

  5. Java目录事件

    当文件系统中的对象被修改时,我们可以监听watch服务以获取警报.java.nio.file包中的以下类和接口提供watch服务. Watchable接口 WatchService接口 WatchKe ...

  6. 8.1_springboot2.x之Actuator应用监控

    1.监管端点测试 引入依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=&qu ...

  7. python初学者学习工具安装教程&安装步骤详解

    一.python安装: ​ 版本:3.6.8 ​ 下载地址:https://www.python.org/downloads/ 安装步骤截图: 1.点击python安装包,出现下图所示界面,注意勾选A ...

  8. hdu6537 /// DP 最长不降子序列->最长公共子序列

    题目大意: 给定一个字符串 字符为0~9 求翻转某个区间后使得串中的最长不降子序列最长 因为字符范围为0~9 假设有一个 0 1 2 3 4 5 6 7 8 9 的序列 此时翻转某个区间得到形如 0 ...

  9. Android网络(3):HttpClient作client,Tomcat Servlet作server的交互演示样例

    前面相继介绍了Android网络编程里的Socket传输图片.HttpURLConnection,今天看HttpClient. 第一部分:JavaEE版的Eclipse配置Tomcat [备注:开发后 ...

  10. 自定义可点击的ImageSpan并在TextView中内置“View“

    有的时候可能想在TextView中添加一些图片,比如下图,发短信输入联系人时,要把联系人号码换成一个图片,但这个图片无法用固定的某张图,而是根据内容进行定制的,这更像一个view. 当然,如果你不是v ...