[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$号节 ...
随机推荐
- Windows node.js安装运行npm显示类似"ENOENT, stat 'C:\Users\XXXX\AppData\Roaming\npm'错误
这个错误是在玩一个小的博客的时候,使用到node.js,正好使用的是windows系统就安装了一个windows32的node.js版本 结果一运行npm就出现如上的错误,后来发现,只要在上面提到的目 ...
- 秒懂Vuejs、Angular、React原理和前端发展历史
「前端程序发展的历史」 「 不学自知,不问自晓,古今行事,未之有也 」 我们都知道现在流行的框架:Vue.Js.AngularJs.ReactJs,已经逐渐应用到各个项目和实际应用中,它们都是MVVM ...
- Vim实用技巧(一)
vim 命令按键规定 标记 含义 x 按一次 x dw 按一次 d, w dap 按一次 d, a, p 同时按 和 n g<C-]> 按 g, 然后同时按 和 ] <C-=> ...
- C++ 统计输入的句子有多少英文字母
// ConsoleApplication1.cpp: 定义控制台应用程序的入口点.//#include "stdafx.h"#include <iostream>#i ...
- [BZOJ 3771] Triple(FFT+容斥原理+生成函数)
[BZOJ 3771] Triple(FFT+生成函数) 题面 给出 n个物品,价值为别为\(w_i\)且各不相同,现在可以取1个.2个或3个,问每种价值和有几种情况? 分析 这种计数问题容易想到生成 ...
- MATLAB图像的代数运算
1.图像旋转与缩放 bm=imread("3.png"); %subplot(1,3,1); imshow(bm); %缩放图片 %bt=imresize(bm,0.5,'near ...
- how to install protobuff python
当前环境: operate system: Ubuntu 14.04.1 LTS protoc --version: libprotoc 2.5.0 protocol-buffers versi ...
- Android数据库使用指南(上)
前言Android上的数据库是sqlite,虽然这个数据库是轻量级的,但是储存的东西可不少,sqlite官方表示理论存储容量为140TB,目前应该没有那么大容量的手机,存储能力太强了. 关于如何使用S ...
- freemarker如何在url中传递中文参数
例如:http://www.map512.cn/findPOI.do?key=南门如果不转码,request.getParameter("key")返回的是乱码,在jsp中,我们一 ...
- 面试编程题拾遗(06) --- 打印n对括号的全部有效组合
如题所述,当n=3时,可能的组合有:(()()), ((())), ()(()), (())(), ()()() 代码如下(有注释): import java.util.ArrayList; impo ...