欢迎访问~原文出处——博客园-zhouzhendong

去博客园看该题解


题目传送门 - BZOJ5045


题意概括

  有一堵墙。

  

  现在挖掉某些砖。如果有相邻的某两个砖没有了,那么他们中上方的那块也没了。

  比如(0,0)和(0,2)被挖掉了,那么(1,1)也没了; (1,1)没了(1,3)没了,那么(2,2)也没了。

  现在挖掉n(n<=100000)块砖,问会掉多少块砖;

  砖块坐标<=109


题解

  我们按照纵坐标离散化。

  我们把对于最低行的所有砖块改成用许多条线段不重复覆盖的形式。这个需要排序和线性处理。

  每条线段可以弄掉的位置为一个以线段为底的三角形区域。

  然后跳转往上到第二个纵坐标。

  枚举原来处理过的线段。如果线段能打掉的三角形的顶点在当前纵坐标之上,那么我们把一个新的梯形区域记入,并构成一条当前纵坐标的线段。

  如果顶点在下面,那么直接统计即可。

  对于现在,有两类线段,一种是从下面继承的,一种是当前原有的。

  其实没什么区别的。

  直接按照对最低行的处理搞一搞就可以了。

  然后循环解决。

  这样的时间复杂度是O(nlogn)的。

  为什么?因为我们把所有的线段看一看。我们发现,由x块砖构成的线段,最多可以演变成x条纵坐标不同的线段,那么不同的线段总数<=n。

  对于每一条不同的线段,处理的均摊复杂度为O(logn);最多n条不同线段,那么O(nlogn);

  具体处理还是也具体看待。


代码

#include <cstring>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long LL;
const int N=100000+5;
int n,x[N],xz;
LL ans=0;
struct Point{
int x,y;
}p[N];
struct vec{
Point seg[N];
int z;
void clear(){
z=0;
}
void push(int a,int b){
seg[++z].x=a,seg[z].y=b;
}
}a,b;
bool cmpx(Point a,Point b){
return a.x<b.x;
}
int main(){
scanf("%d",&n);
for (int i=1;i<=n;i++)
scanf("%d%d",&p[i].x,&p[i].y),x[i]=p[i].x;
sort(p+1,p+n+1,cmpx);
sort(x+1,x+n+1);
xz=1;
for (int i=2;i<=n;i++)
if (x[i]!=x[i-1])
x[++xz]=x[i];
a.clear();
for (int pos=1,xp=1;pos<=n,xp<=xz;xp++){
b.clear();
for (int i=1;i<=a.z;i++){
int L=a.seg[i].x,R=a.seg[i].y,w=(R-L)/2,dx=x[xp]-x[xp-1];
if (w<=dx)
ans+=1LL*w*(w+1)/2;
else {
ans+=1LL*(w+w-dx+1)*dx/2;
b.push(L+dx,R-dx);
}
}
for (;p[pos].x==x[xp];pos++)
b.push(p[pos].y,p[pos].y+2);
sort(b.seg+1,b.seg+b.z+1,cmpx);
a.clear();
vec &c=a;
for (int i=1;i<=b.z;i++)
if (c.z==0||c.seg[c.z].y<b.seg[i].x)
c.push(b.seg[i].x,b.seg[i].y);
else
c.seg[c.z].y=max(c.seg[c.z].y,b.seg[i].y);
}
for (int i=1;i<=a.z;i++){
int L=a.seg[i].x,R=a.seg[i].y,w=(R-L)/2;
ans+=1LL*w*(w+1)/2;
}
printf("%lld",ans);
return 0;
}

  

BZOJ5045 打砖块 2017年9月月赛 其他的更多相关文章

  1. BZOJ5047 空间传送装置 2017年9月月赛 最短路 SPFA

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ5047 题意概括 概括??~别为难语文做一题错两题的我了…… 题解 我们发现,对于某一种装置,有c种 ...

  2. 猖獗的假新闻:2017年1月1日起iOS的APP必须使用HTTPS

    一.假新闻如此猖獗 刚才一位老同事 打电话问:我们公司还是用的HTTP,马上就到2017年了,提交AppStore会被拒绝,怎么办? 公司里已经有很多人问过这个问题,回答一下: HTTP还是可以正常提 ...

  3. [转载]Ubuntu17.04(Zesty Zapus)路线图发布:2017年4月13日发布

    Canonical今天公布了Ubuntu 17.04(Zesty Zapus)操作系统的发布路线图,该版本于今年10月24日上线启动,toolchain已经上传且首个daily ISO镜像已经生成.面 ...

  4. 最新IP地址数据库Dat格式-高性能高并发版(2017年1月)

    最新IP地址数据库->Dat格式 高性能格式->qqzeng-ip.dat 国内版-20170101-Dat 版                国外版-20170101-Dat 版     ...

  5. 2017年1月5日 星期四 --出埃及记 Exodus 21:31

    2017年1月5日 星期四 --出埃及记 Exodus 21:31 This law also applies if the bull gores a son or daughter.牛无论触了人的儿 ...

  6. 2017年1月4日 星期三 --出埃及记 Exodus 21:30

    2017年1月4日 星期三 --出埃及记 Exodus 21:30 However, if payment is demanded of him, he may redeem his life by ...

  7. 2017年1月3日 星期二 --出埃及记 Exodus 21:29

    2017年1月3日 星期二 --出埃及记 Exodus 21:29 If, however, the bull has had the habit of goring and the owner ha ...

  8. 2017年1月2日 星期一 --出埃及记 Exodus 21:28

    2017年1月2日 星期一 --出埃及记 Exodus 21:28 "If a bull gores a man or a woman to death, the bull must be ...

  9. 2017年1月1日 星期日 --出埃及记 Exodus 21:27

    2017年1月1日 星期日 --出埃及记 Exodus 21:27 And if he knocks out the tooth of a manservant or maidservant, he ...

随机推荐

  1. Spring Boot 系列 @ControllerAdvice 拦截异常并统一处理

    ControllerAdvice用法解析 简介 通过@ControllerAdvice注解可以将对于控制器的全局配置放在同一个位置. 注解了@Controller的类的方法可以使用@Exception ...

  2. linux space/mark设置

    参考链接: http://blog.csdn.net/zhaozh2000/article/details/6460223 串口数据的发送: 数据的发送: 数据位+检验位+停止位, 进行数据的发送.( ...

  3. mysql 案例~关于pt-osc工具的用途

    简介:今天咱们聊聊PT-OSC的东东一 简单介绍  1 标准组合   pt-online-schema-change --user= --password= --host= D=,t= --sock= ...

  4. VMware xp系统联网

    1.

  5. 【ARTS】01_12_左耳听风-20190128~20190203

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  6. Pcap4J实现抓包器

    前段时间搞抓包程序,打算使用Pcap4J实现,发现除了GitHub,其它资料少之又少,几乎都是不起作用. 被迫我一直看(日本作者!)英文注解的源码和sample和test,比较费劲+营养很少.因为几乎 ...

  7. passwd: Have exhausted maximum number of retries for service【转】

    使用命令passwd修改密码时,遇到如下问题: # echo 'utf8'|passwd zhangsan --stdin Changing password for user zhangsan. p ...

  8. windows下解压zip包,包含中文解析

    #coding=utf8 import os import zipfile import sys,locale # 本来以为需要,结果不需要 # def p(f): # #print '%s.%s() ...

  9. 【转】void及void指针的深刻解析

    void的含义 void即“无类型” ,void*则为“无类型指针”,可以指向任何数据类型,所以又叫做“通用指针”. void指针使用规范 ①void指针可以只想任意类型的数据,亦即可用任意数据类型的 ...

  10. 解决服务器代码执行mvn test后在classes和test-classes下找不到Spring的bean.xml配置文件问题

    昨天在jenkins构建代码后,执行mvn test 就报错如下: 提示的bean.xm不存在呀, 再来看源码ApplicationContext 的声明 ApplicationContext ctx ...