传送门

https://www.cnblogs.com/violet-acmer/p/10146350.html

题意:

  有一块 n*m 的棋盘,初始,黑白块相间排列,且左下角为白块。

  给出两个区间[ (x1,y1) , (x2,y2) ] 和 [ (x3,y3) , (x4,y4) ],第一个区间全部涂成白色,第二个区间全部涂成黑色,且颜色会覆盖。

  求两块区间按照要求涂完后白块和黑快的个数?

题解:

  我的想法如下:

  先求出初始的黑块个数,然后,求出第一个区间减少的黑块个数,再求出第二个区间增加的黑块个数,求出黑块个数后,白块个数也就出来了。

  具体求法:

  

  如何求出初始黑块个数呢?

  定义变量 totBlack 为黑块个数。

  看图,你会发现第一列与第二列黑块的总和 ==8(n)

  也就是说,前m列会有(m/2)*8个黑块,如果m为奇数,那么就会剩下最后一列不能配对,而最后一列的黑块的个数就是 n/2;

  在经过观察,你会发现,黑块的坐标加和 x+y 为奇数,知道这个后,问题将变得异常简单。

  首先[(x1,y1),(x2,y2)]区间1的所有黑块都会被涂成白块,求出此区间的黑块个数 totBlack1,totBlack -= totBlack1;

  而[(x3,y3),(x4,y4)]区间2的所有白块会被涂成黑块,如果区间1和区间2不重合,问题会变得很简单,但,如果重合呢?

  先不考虑重合的问题,单纯的求出区间2的白块个数 totBlack3,totBlack += totBlack3;

  对于重合的部分,求出重合部分的黑块个数 totBlack4,totBlack += totBlack4;

  因为,区间1会把重合部分的黑块变为白块,而区间2在查找白块的时候会忽略重合区间的黑块部分,而这部分正好是少加的。

  具体细节看代码。

  补充一点计算几何的小知识点,如何求出重合矩形?

  

  此题中给的两个坐标正好是左下和右上,很友好,哈哈哈~~~~~~~

AC代码:

 #include<iostream>
#include<cstdio>
using namespace std;
#define ll __int64 ll n,m;
struct Node
{
int x1,y1;
int x2,y2;
Node(int a=,int b=,int c=,int d=)
{
x1=a,y1=b;
x2=c,y2=d;
}
}rec[]; //i == 1 : 查找[(x1,y1),(x2,y2)]黑块个数
//i == 2 : 查找[(x3,y3),(x4,y4)]白块个数
//i == 3 : 查找重合区间的黑块个数
ll Find1(int i)
{
int totX=rec[i].x2-rec[i].x1+;
int totY=rec[i].y2-rec[i].y1+; ll res=;
if(totX >= )
res=1ll*totY*(totX>>);
if(totX&)//如果totX为奇数,那么之前两两配对后,会剩下最后一列没被统计
{
if(i&)//查找最后一列黑块个数
{
if(rec[i].x2&)//x2为奇,找y为偶的个数
res += (totY>>)+((totY&) && (rec[i].y1% == ) ? :);
else//x为偶数,找y为奇的个数
res += (totY>>)+((totY&) && (rec[i].y1&) ? :);
}
else//查找最后一列白块个数
{
if(rec[i].x2&)//x2为奇,找y为奇的个数
res += (totY>>)+((totY&) && (rec[i].y1&) ? :);
else//x为偶数,找y为偶的个数
res += (totY>>)+((totY&) && (rec[i].y1% == ) ? :);
}
}
return res;
}
ll Find2()
{
ll res=Find1();
int a=max(rec[].x1,rec[].x1),b=max(rec[].y1,rec[].y1);
int c=min(rec[].x2,rec[].x2),d=min(rec[].y2,rec[].y2);
if(a > c || b > d)
return res; rec[]=Node(a,b,c,d);
res += Find1();//查找重合部分黑块的个数
return res;
}
void Solve()
{
ll totBlack=;
if(m >= )
totBlack=n*(m>>);
totBlack += ((m&) ? (n>>):); totBlack -= Find1();//去掉第一个区间减少的黑块个数
totBlack += Find2();//加上第二个区间增加的黑块个数 printf("%I64d %I64d\n",n*m-totBlack,totBlack);
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int a,b,c,d;
scanf("%I64d%I64d",&n,&m); scanf("%d%d%d%d",&a,&b,&c,&d);
rec[]=Node(a,b,c,d); scanf("%d%d%d%d",&a,&b,&c,&d);
rec[]=Node(a,b,c,d); Solve();
}
return ;
}

  这道题,踩了范围的坑!!!!!

  中间定义的一些变量是 int ,但是由于含有乘法操作,中间结果会溢出 int 范围,然后,改了好久好久~~~~~~

  

  一直在wa在text2数据,后来发现,越界了,改成 res=1ll*totY*(totX>>1)才过的

  顶着明天Linux考试要挂科的风险再次码了好久好久代码。。。。

  考前磨磨枪吧,万一过了呢!!!!!!!

  代码有毒,上瘾,哈哈哈,可我就是喜欢啊

Codeforces Round #524 (Div. 2) C. Masha and two friends(思维+计算几何?)的更多相关文章

  1. 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 ...

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

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

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

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

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

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

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

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

  6. Codeforces Round #556 (Div. 2) - C. Prefix Sum Primes(思维)

    Problem  Codeforces Round #556 (Div. 2) - D. Three Religions Time Limit: 1000 mSec Problem Descripti ...

  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. JAVA锁机制-可重入锁,可中断锁,公平锁,读写锁,自旋锁,

    如果需要查看具体的synchronized和lock的实现原理,请参考:解决多线程安全问题-无非两个方法synchronized和lock 具体原理(百度) 在并发编程中,经常遇到多个线程访问同一个 ...

  2. mvn clean compile package install deploy

    (1) package 目的是打包,在pom中,如果是jar就会打包成jar,如果是war就会打包成war 在pom.xml中: <modelVersion></modelVersi ...

  3. Lodop连续打印内容逐渐偏移怎么办

    Lodop打印控件中,可以使用打印机自带的纸张名称,也可以自定义纸张.(SET_PRINT_PAGESIZE语句).通常进行打印开发,为了避免浪费纸张,会用虚拟打印机效果作为依据,虚拟打印机连续打印多 ...

  4. Scss - 简单笔记

    原文链接:scss 教程 手头上疯狂在用 scss,虽然可以在里面写原生的 css, 但是为了保持风格的一致性,还是滚去看了看 scss 文档. 一.变量 变量的引入是 scss 的一个核心特性,变量 ...

  5. Visual Studio常用插件整理

    Visual Studio Tools for Git       GIT代码管理工具 Resharper           代码生成工具 CSOutline2017      语法级别的代码折叠 ...

  6. Using MongoDB with Web API and ASP.NET Core

    MongoDB is a NoSQL document-oriented database that allows you to define JSON based documents which a ...

  7. 洛谷 P3951 小凯的疑惑

    题目链接 一开始看到这题,我的内心是拒绝的. 以为是同余类bfs,一看数据1e9,发现只能允许O(1)的算法,数学还不太好,做不出来,其实应该打表找规律. 看到网上的题解,如果两个都必须拿,结果一定是 ...

  8. HUST 1555 数学作业

    参考自:https://www.cnblogs.com/ECJTUACM-873284962/p/6394892.html 1555 - A Math Homework 时间限制:1秒 内存限制:12 ...

  9. Matplotlib学习---用matplotlib画阶梯图(step plot)

    这里利用Nathan Yau所著的<鲜活的数据:数据可视化指南>一书中的数据,学习画图. 数据地址:http://datasets.flowingdata.com/us-postage.c ...

  10. Iroha and a Grid AtCoder - 1974(思维水题)

    就是一个组合数水题 偷个图 去掉阴影部分  把整个图看成上下两个矩形 对于上面的矩形求出起点到每个绿点的方案 对于下面的矩形 求出每个绿点到终点的方案 上下两个绿点的方案相乘后相加 就是了 想想为什么 ...