codeforces round#524 C. Masha and two friends /// 矩形切割
题目大意:
给定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 /// 矩形切割的更多相关文章
- Codeforces Round #524 (Div. 2)(前三题题解)
这场比赛手速场+数学场,像我这样读题都读不大懂的蒟蒻表示呵呵呵. 第四题搞了半天,大概想出来了,但来不及(中途家里网炸了)查错,于是我交了两次丢了100分.幸亏这次没有掉rating. 比赛传送门:h ...
- 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 ...
- Codeforces Round #524 (Div. 2) C. Masha and two friends
C. Masha and two friends 题目链接:https://codeforc.es/contest/1080/problem/C 题意: 给出一个黑白相间的n*m的矩阵,现在先对一个子 ...
- Codeforces Round #524 (Div. 2) C. Masha and two friends(思维+计算几何?)
传送门 https://www.cnblogs.com/violet-acmer/p/10146350.html 题意: 有一块 n*m 的棋盘,初始,黑白块相间排列,且左下角为白块. 给出两个区间[ ...
- Codeforces Round #524 (Div. 2) C. Masha and two friends 几何:判断矩形是否相交以及相交矩形坐标
题意 :给出一个初始的黑白相间的棋盘 有两个人 第一个人先用白色染一块矩形区域 第二个人再用黑色染一块矩形区域 问最后黑白格子各有多少个 思路:这题的关键在于求相交的矩形区间 给出一个矩形的左下和 ...
- Codeforces Round #524 (Div. 2) C. Masha and two friends 思路
题目:题目链接 思路:直接计数显然是不好处理的,但分情况讨论只要不写错这题是一定可以出的,但这样基本做完这个题就没时间做其他题了,但当时我就这么蠢的这样做了,比赛一个半小时的时候突然发现一个似乎可行的 ...
- Codeforces Round #524 (Div. 2) Masha and two friends矩形
题目 题意: 给一个n*m块大的黑白相间的矩形,在这个举行中操作,要先把第一个矩形(左下角坐标(x1,y2),右上角坐标(x2,y2)) 全部涂成白色,再把第二个矩形(左下角坐标(x3,y3), ...
- 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 ...
- Codeforces Round #524 (Div. 2) E. Sonya and Matrix Beauty(字符串哈希,马拉车)
https://codeforces.com/contest/1080/problem/E 题意 有一个n*m(<=250)的字符矩阵,对于每个子矩阵的每一行可以任意交换字符的顺序,使得每一行每 ...
随机推荐
- 转-C++之手写strcpy
转自:strcpy函数的实现 知strcpy函数的原型是: char *strcpy(char *dst, const char *src); 实现strcpy函数 解释为什么要返回char * 假如 ...
- CSS:CSS 图像透明/不透明
ylbtech-CSS:CSS 图像透明/不透明 1.返回顶部 1. CSS 图像透明/不透明 使用CSS很容易创建透明的图像. 注意:CSS Opacity属性是W3C的CSS3建议的一部分. 更多 ...
- Codeforcs 1183B Equalize Prices
题目链接:codeforces.com/problemset/problem/1183/B 题意:给你 n 个数,每个数能在k范围内上下浮动,求能否使所有数相等,能输出相等的最大值,不能输出 -1. ...
- hibernate 中createQuery与createSQLQuery两者区别
hibernate 中createQuery与createSQLQuery两者区别是:前者用的hql语句进行查询,后者可以用sql语句查询前者以hibernate生成的Bean为对象装入list返回, ...
- python3 递归函数return返回None
今天写了一个函数,执行之后打印出来的结果是None,不明白,之后百度了一下,这里记一下过程,免得之后再踩坑 #!/usr/bin/python3# -*- coding:utf-8 -*- def b ...
- python调用tushare获取A股上市公司管理层人员信息
接口:stk_managers 描述:获取上市公司管理层 注:tushare模块下载和安装教程,请查阅我之前的文章 积分:用户需要2000积分才可以调取,具体请参阅本文最下方积分获取办法 输入参数 名 ...
- 4-Ubuntu-启动/关闭/重启mysql服务
启动: sudo service mysql start 关闭: sudo service mysql stop 重启: sudo service mysql restart
- git config配置,工作区和版本库联系。
关于git和github的介绍,我这边不多说. 使用在windows下使用git,需要配置环境变量,也可以使用git自带的终端工具.,打开git bash laoni@DESKTOP-TPPLHIB ...
- springboot + zipkin + mysql
zipkin的数据存储可以存在4个地方: 内存(仅用于测试,数据不会持久化,zipkin-server关掉,数据就没有了) 这也是之前使用的 mysql 可能是最熟悉的方式 es Cassandra ...
- Mac上Chrome浏览器跨域解决方案
现在比较新的浏览器在本地调试时AJAX请求,基本都会有跨域问题.相应的解决方案也挺多的,工具也不少.像charles等抓包工具等.不过最简单的就是移除浏览器的同源限制. 我们要做的第一步,就是创建一个 ...