[CSP-S模拟测试]:辣鸡(ljh) (暴力)
题目描述
辣鸡$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) (暴力)的更多相关文章
- 7.29 NOIP模拟测试10 辣鸡(ljh)+模板(ac)+大佬(kat)
T1 辣鸡(ljh) 就是一道分类讨论的暴搜,外加一丢丢的减枝,然而我挂了,为啥呢,分类讨论变量名打错,大于小于号打反,能对才怪,写了sort为了调试就注释了,后来忘了解开,小减枝也没打.但是这道题做 ...
- noip模拟6[辣鸡·模板·大佬·宝藏]
这怕不是学长出的题吧 这题就很迷 这第一题吧,正解竟然是O(n2)的,我这是快气死了,考场上一直觉得aaaaa n2过不了过不了, 我就去枚举边了,然后调了两个小时,愣是没调出来,然后交了个暴力,就走 ...
- [NOIP模拟测试10]辣鸡(ljh) 题解
首先计算块内贡献,很显然是$(x_2-x_1)*(y_2-y_1)*2$. 然后考虑矩形之间的贡献,sort一遍分类讨论$n^2$暴力即可. 注意考虑边界情况是否能多两个,以及角对角的情况. 另外,排 ...
- [CSP-S模拟测试]:打扫卫生(暴力)
题目描述 有$N$头奶牛,每头那牛都有一个标号$P_i1\leqslant Pi\leqslant M\leqslant N\leqslant 40,000$.现在$Farmer\ John$要把这 ...
- [CSP-S模拟测试]:String Master(暴力)
题目描述 所谓最长公共子串,比如串$A:"abcde"$,串$B:"jcdkl"$,则它们的最长公共子串为串$"cd"$,即长度最长的字符串 ...
- HZOJ 辣鸡(ljh)
题解?noipT1还需要题解?正解就是$n^2$大暴力. 考试的时候打了$n^2$的暴力,也想到了正解的优化,然而觉得它太麻烦了,而且$n^2$怎么优化也过不了50000啊,而且即使不优化前面30分我 ...
- NOIP 模拟 6 辣鸡
题解 难得啊,本来能 \(AC\) 的一道题,注释没删,挂了五分,难受 此题暴力很好想,就是直接 \(n^2\) 枚举不同的矩阵组合,记录块内答案和跨块的答案 出题人不会告诉你,这题只要输出块内答案就 ...
- 2019.7.29 NOIP模拟测试10 反思总结【T2补全】
这次意外考得不错…但是并没有太多厉害的地方,因为我只是打满了暴力[还没去推T3] 第一题折腾了一个小时,看了看时间先去写第二题了.第二题尝试了半天还是只写了三十分的暴力,然后看到第三题是期望,本能排斥 ...
- [CSP-S模拟测试]:模板(ac)(线段树启发式合并)
题目描述 辣鸡$ljh\ NOI$之后就退役了,然后就滚去学文化课了.他每天都被$katarina$大神虐,仗着自己学过一些姿势就给$katarina$大神出了一道题.有一棵$n$个节点的以$1$号节 ...
随机推荐
- Nginx日志监控 使用 goaccess查看nginx日志
nginx日志监控 yum install goaccess 安装使用教程 goaccess access.log -o ../html/report.html --real-time-html ...
- [集合]HashMap和Hashtable区别
底层 哈希算法,双列集合 HashMap 线程不安全,效率高,JDK1.2版本 Hashtable 线程安全,效率低,JDK1.0版本 HashMap 可以存储 null 键和 null 值 ...
- Javascript的是三种字符串连接方式
第一种:用连接符“+”连接字符串 str="a"; str+="b"; 这种方法相对以下两种,最便捷快速.建议100字符以下的连接使用这种连接方式. 第二种:以 ...
- 网络爬虫之JSOUP
JSOUP中文文档:http://www.open-open.com/jsoup/推荐博客:http://www.cnblogs.com/jycboy/p/jsoupdoc.html 从一个URL加载 ...
- 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 ...
- mysql常见函数及其用例
函数调用:select 函数名(实参列表) [from 表]; 函数分类: 1.单行函数 如 concat.length.ifnull等. 2.分组函数 功能:做统计使用,又称为统计函数.聚合函数.组 ...
- vue + nginx部署404
记录: vue项目打包放到服务器,使用nginx反向代理的时候路由页面刷新报404,因为刷新时,不存在路径对应的文件或文件夹,需要在nginx配置中添加代码: index index.html; tr ...
- CRMEasy知识库点击无法弹出窗体问题
丢失控件 MSDATLST.OCX 将此控件放在路径下 C:\Windows\System32 并进行注册,具体方法为: 打开控件方式选择 C:\Windows\System32\reg ...
- vue无线滚动组件封装
<template> <div class="scroll-wapper" :style="{height: scrollHeight + 'px'}& ...
- AngularJS中forEach的用法
AngularJS中当我们需要遍历某个数组的时候,我们会用到forEach语法.AngularJS中forEach的用法如下: angular.forEach(array,function(obj,i ...