题目描述

辣鸡$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. Nginx日志监控 使用 goaccess查看nginx日志

    nginx日志监控 yum install goaccess   安装使用教程 goaccess access.log -o ../html/report.html --real-time-html ...

  2. [集合]HashMap和Hashtable区别

    底层 哈希算法,双列集合 HashMap 线程不安全,效率高,JDK1.2版本    Hashtable 线程安全,效率低,JDK1.0版本 HashMap 可以存储 null 键和 null 值   ...

  3. Javascript的是三种字符串连接方式

    第一种:用连接符“+”连接字符串 str="a"; str+="b"; 这种方法相对以下两种,最便捷快速.建议100字符以下的连接使用这种连接方式. 第二种:以 ...

  4. 网络爬虫之JSOUP

    JSOUP中文文档:http://www.open-open.com/jsoup/推荐博客:http://www.cnblogs.com/jycboy/p/jsoupdoc.html 从一个URL加载 ...

  5. 34. Find First and Last Position of Element in Sorted Array (JAVA)

    Given an array of integers nums sorted in ascending order, find the starting and ending position of ...

  6. mysql常见函数及其用例

    函数调用:select 函数名(实参列表) [from 表]; 函数分类: 1.单行函数 如 concat.length.ifnull等. 2.分组函数 功能:做统计使用,又称为统计函数.聚合函数.组 ...

  7. vue + nginx部署404

    记录: vue项目打包放到服务器,使用nginx反向代理的时候路由页面刷新报404,因为刷新时,不存在路径对应的文件或文件夹,需要在nginx配置中添加代码: index index.html; tr ...

  8. CRMEasy知识库点击无法弹出窗体问题

    丢失控件   MSDATLST.OCX 将此控件放在路径下    C:\Windows\System32 并进行注册,具体方法为: 打开控件方式选择   C:\Windows\System32\reg ...

  9. vue无线滚动组件封装

    <template> <div class="scroll-wapper" :style="{height: scrollHeight + 'px'}& ...

  10. AngularJS中forEach的用法

    AngularJS中当我们需要遍历某个数组的时候,我们会用到forEach语法.AngularJS中forEach的用法如下: angular.forEach(array,function(obj,i ...