题目描述

辣鸡$ljh\ NOI$之后就退役了,然后就滚去学文化课了。
然而在上化学课的时候,数学和化学都不好的$ljh$却被一道简单题难住了,受到了大佬的嘲笑。
题目描述是这样的:
在一个二维平面上有一层水分子,请问形成了多少个氢键?
这个二维平面可以看做一个类似棋盘的东西,每个格子可以容纳一个水分子,左下角的格子为$(0,0)$,这个格子右边的格子为$(1,0)$,上方格子为$(0,1)$,以此类推。
辣鸡$ljh$当然不会做了,所以他来求助$JeremyGou$,$JeremyGou$一眼就看穿了真相,并想用这道题来考一考正在做$NOIP$模拟赛的你。
注:在本题中,我们认为一个水分子能与和它曼哈顿距离为$2$且直线距离小于$2$的其他格子形成氢键。


输入格式

一个整数$n$。
接下来$n$行,每行给出四个整数$x_1,y_1,x_2,y_2$。
表示以$(x_1,y_1)$为左下角,$(x_2,y_2)$为右上角的矩形中每个格子都有一个水分子。
给出的所有矩形没有交集。


输出格式

一个整数,表示氢键的数量。


样例

样例输入1:

3
0 0 0 0
0 1 1 2
2 2 2 3

样例输出1:

5

样例输入2:

10
1 8 8 9
0 3 10 7
0 0 7 0
0 2 9 2
4 10 8 10
10 0 10 2
0 10 0 10
8 0 9 1
0 8 0 9
9 8 10 8

样例输出2:

157


数据范围与提示

样例$1$解释:

左图为水分子的排布,右图中的绿色线条表示氢键。

$N\leqslant {10}^5$。

$x\leqslant {10}^9$。

$y\leqslant {10}^9$。

自己画的样例$2\downarrow$:


题解

$15\%$算法:

开一个临接矩阵,存一下,在里面$\Theta(\max(x_{2_i},y_{2_i})^2)$跑一遍就好了。

$35\%$算法:

$\Theta(n^2)$枚举每对矩形,统计它们之间形成的贡献,在加上它们内部的贡献即可。

$65\%$算法:

$\Theta(n)$枚举每个矩形,输出它们的内部贡献,即$(x_2-x_1)\times(y_2-y_1)\times 2$,是不是很震惊?!?!

$100\%$算法:

先按$x_1$的大小排个序,然后再进行$\Theta(n^2)$进行枚举,如果$x_j-x_i>1$则$break$。

统计答案的时候分4种情况:

  $\alpha.$每个矩形自己内部的贡献。

  $\beta.$两个矩形左右相接。

  

if(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1)>=0)
{
if(e[i].y2==e[j].y1-1)
{
ans+=(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1))<<1;
if(e[i].x1!=e[j].x1)ans++;
if(e[i].x2!=e[j].x2)ans++;
}
if(e[j].y2==e[i].y1-1)
{
ans+=(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1))<<1;
if(e[i].x1!=e[j].x1)ans++;
if(e[i].x2!=e[j].x2)ans++;
}
}

  $\chi.$两个矩形上下相接。

  

if(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1)>=0)
{
if(e[i].x2==e[j].x1-1)
{
ans+=(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1))<<1;
if(e[i].y1!=e[j].y1)ans++;
if(e[i].y2!=e[j].y2)ans++;
}
if(e[j].x2==e[i].x1-1)
{
ans+=(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1))<<1;
if(e[i].y1!=e[j].y1)ans++;
if(e[i].y2!=e[j].y2)ans++;
}
}

  $\delta.$两个矩形对角

  

if(e[i].x2==e[j].x1-1&&(e[i].y2==e[j].y1-1||e[i].y1==e[j].y2+1))ans++;

这就是正解?!?!

没错,至少出题人这么说的;而对于这道题,出题人就是老大……


代码时刻

#include<bits/stdc++.h>
using namespace std;
struct rec
{
int x1;
int y1;
int x2;
int y2;
}e[100001];
long long ans;
bool cmp1(rec a,rec b){return a.x1<b.x1;}
int main()
{
int n;
scanf("%d",&n);
for(register int i=1;i<=n;i++)
{
scanf("%d%d%d%d",&e[i].x1,&e[i].y1,&e[i].x2,&e[i].y2);
ans+=1LL*(e[i].x2-e[i].x1)*(e[i].y2-e[i].y1);
}
ans<<=1;
sort(e+1,e+n+1,cmp1);
for(register int i=1;i<n;i++)
for(register int j=i+1;j<=n;j++)
{
if(e[j].x1-e[i].x2>1)break;
if(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1)>=0)
{
if(e[i].y2==e[j].y1-1)
{
ans+=(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1))<<1;
if(e[i].x1!=e[j].x1)ans++;
if(e[i].x2!=e[j].x2)ans++;
}
if(e[j].y2==e[i].y1-1)
{
ans+=(min(e[i].x2,e[j].x2)-max(e[i].x1,e[j].x1))<<1;
if(e[i].x1!=e[j].x1)ans++;
if(e[i].x2!=e[j].x2)ans++;
}
}
if(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1)>=0)
{
if(e[i].x2==e[j].x1-1)
{
ans+=(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1))<<1;
if(e[i].y1!=e[j].y1)ans++;
if(e[i].y2!=e[j].y2)ans++;
}
if(e[j].x2==e[i].x1-1)
{
ans+=(min(e[i].y2,e[j].y2)-max(e[i].y1,e[j].y1))<<1;
if(e[i].y1!=e[j].y1)ans++;
if(e[i].y2!=e[j].y2)ans++;
}
}
if(e[i].x2==e[j].x1-1&&(e[i].y2==e[j].y1-1||e[i].y1==e[j].y2+1))ans++;
}
printf("%lld",ans);
return 0;
}

rp++

[CSP-S模拟测试]:辣鸡(ljh) (暴力)的更多相关文章

  1. 7.29 NOIP模拟测试10 辣鸡(ljh)+模板(ac)+大佬(kat)

    T1 辣鸡(ljh) 就是一道分类讨论的暴搜,外加一丢丢的减枝,然而我挂了,为啥呢,分类讨论变量名打错,大于小于号打反,能对才怪,写了sort为了调试就注释了,后来忘了解开,小减枝也没打.但是这道题做 ...

  2. noip模拟6[辣鸡·模板·大佬·宝藏]

    这怕不是学长出的题吧 这题就很迷 这第一题吧,正解竟然是O(n2)的,我这是快气死了,考场上一直觉得aaaaa n2过不了过不了, 我就去枚举边了,然后调了两个小时,愣是没调出来,然后交了个暴力,就走 ...

  3. [NOIP模拟测试10]辣鸡(ljh) 题解

    首先计算块内贡献,很显然是$(x_2-x_1)*(y_2-y_1)*2$. 然后考虑矩形之间的贡献,sort一遍分类讨论$n^2$暴力即可. 注意考虑边界情况是否能多两个,以及角对角的情况. 另外,排 ...

  4. [CSP-S模拟测试]:打扫卫生(暴力)

    题目描述 有$N$头奶牛,每头那牛都有一个标号$P_i1\leqslant Pi\leqslant M\leqslant N\leqslant 40,000$.现在$Farmer\  John$要把这 ...

  5. [CSP-S模拟测试]:String Master(暴力)

    题目描述 所谓最长公共子串,比如串$A:"abcde"$,串$B:"jcdkl"$,则它们的最长公共子串为串$"cd"$,即长度最长的字符串 ...

  6. HZOJ 辣鸡(ljh)

    题解?noipT1还需要题解?正解就是$n^2$大暴力. 考试的时候打了$n^2$的暴力,也想到了正解的优化,然而觉得它太麻烦了,而且$n^2$怎么优化也过不了50000啊,而且即使不优化前面30分我 ...

  7. NOIP 模拟 6 辣鸡

    题解 难得啊,本来能 \(AC\) 的一道题,注释没删,挂了五分,难受 此题暴力很好想,就是直接 \(n^2\) 枚举不同的矩阵组合,记录块内答案和跨块的答案 出题人不会告诉你,这题只要输出块内答案就 ...

  8. 2019.7.29 NOIP模拟测试10 反思总结【T2补全】

    这次意外考得不错…但是并没有太多厉害的地方,因为我只是打满了暴力[还没去推T3] 第一题折腾了一个小时,看了看时间先去写第二题了.第二题尝试了半天还是只写了三十分的暴力,然后看到第三题是期望,本能排斥 ...

  9. [CSP-S模拟测试]:模板(ac)(线段树启发式合并)

    题目描述 辣鸡$ljh\ NOI$之后就退役了,然后就滚去学文化课了.他每天都被$katarina$大神虐,仗着自己学过一些姿势就给$katarina$大神出了一道题.有一棵$n$个节点的以$1$号节 ...

随机推荐

  1. [19/06/04-星期二] HTML基础_实体(转义字符)、图片标签(img)、元标签(meta)、语法规范、内联框架(iframe)、超链接

    一.实体(转义字符) 在HTML中,一些诸如<.> 就是普通的小于号和大于号不能直接使用,因为浏览可能会把它当成一个标签去解析,所以需要一些特殊字符去表示这些特殊字符, 这些字符我们称他们 ...

  2. S-阶乘除法

    输入两个正整数 n, m,输出 n!/m!,其中阶乘定义为 n!= 1*2*3*...*n (n>=1). 比如,若 n=6, m=3,则n!/m!=6!/3!=720/6=120. 是不是很简 ...

  3. 用Java构建一个简单的WebSocket聊天室

    前言 首先对于一个简单的聊天室,大家应该都有一定的概念了,这里我们省略用户模块的讲解,而是单纯的先说说聊天室的几个功能:自我对话.好友交流.群聊.离线消息等. 今天我们要做的demo就能帮我们做到这一 ...

  4. Markdown在线编辑及预览

    推荐一款不错的Markdown语法手册,最可贵的是支持在线编辑预览: Cmd Markdown简介 Cmd Markdown语法手册及在线编辑 补充一些使用技巧: MarkDown实现段首缩进:「Ma ...

  5. C#.NET、Power BI、数据挖掘

    阅读目录 1.采集目目标特点与分析 2.方案第一版-Low到爆,别笑话 3.碰壁后的第二版方案 4.最终方案第三版 5.总结 说起采集,其实我是个外行,以前拔过阿里巴巴的客户数据,在我博客的文章:C# ...

  6. 自己写的SqlHelper,提示在调用"Fill"前,SelectCommand 属性尚未初始化.错误

    namespace 操作数据{    class SqlHelper    {        public DataSet SqlTODs(string cmdstring)        {     ...

  7. http参数传递方式

    url传参 这种在各种method(get,post,delete,put)都能使用,解析速度快 body体中的参数 application/x-www-form-urlencoded 这应该是最常见 ...

  8. 如何设置一个App的缓存机制

    在手机应用程序开发中,为了减少与服务端的交互次数,加快用户的响应速度,一般都会在iOS设备中加一个缓存的机制,前面一篇文章介绍了iOS设备的内存缓存,这篇文章将设计一个本地缓存的机制. 功能需求 这个 ...

  9. python引用库异常总结

    一.导入import pandas.io.data as web 时报了"The pandas.io.data module is moved to a separate package & ...

  10. fhq_treap || BZOJ 3223: Tyvj 1729 文艺平衡树 || Luogu P3391 【模板】文艺平衡树(Splay)

    题面: [模板]文艺平衡树(Splay) 题解:无 代码: #include<cstdio> #include<cstring> #include<iostream> ...