Description

Input

Output

扫描线求出平面图的对偶图然后求最小生成树,用并查集按秩合并,以便查询两点间路径最大权

#include<stdio.h>
#include<algorithm>
#include<vector>
#include<set>
#include<cmath>
int f[],f2[],h2[];
int get(int*f,int x){
int a=x,c;
while(x!=f[x])x=f[x];
while(x!=f[a])c=f[a],f[a]=x,a=c;
return x;
}
int get2(int x){
while(x!=f2[x])x=f2[x];
return x;
}
void merge(int a,int b){
a=get(f,a);b=get(f,b);
if(a<b)f[b]=a;
else f[a]=b;
}
double X;
struct ln{
double k,b;int id;
double operator()(double x)const{return k*x+b;}
bool operator<(ln w)const{return operator()(X)+1e-<w(X);}
};
std::set<ln>line;
struct pos{
double x,y;
void R(){
scanf("%lf%lf",&x,&y);
}
}ps[],qs[][];
struct dir{
double d;
int i1,i2;
bool operator<(dir w)const{return d<w.d;}
};
std::vector<dir>vs[];
struct ev{
int t;
double x;
int w;
bool operator<(ev a)const{return x!=a.x?x<a.x:t<a.t;}
}e[];
int ep=,ee[];
int n,m,q;
struct edge{
int a,b,c,ID;
ln l;
void R(int I){
ID=I;
scanf("%d%d%d",&a,&b,&c);
if(ps[a].x>ps[b].x)std::swap(a,b);
if(ps[a].x!=ps[b].x){
e[ep++]=(ev){,ps[a].x,I};
e[ep++]=(ev){,ps[b].x,I};
double k=(ps[b].y-ps[a].y)/(ps[b].x-ps[a].x);
l=(ln){k,ps[a].y-ps[a].x*k,I};
}
vs[a].push_back((dir){atan2(ps[b].y-ps[a].y,ps[b].x-ps[a].x),I,I+m});
vs[b].push_back((dir){atan2(ps[a].y-ps[b].y,ps[a].x-ps[b].x),I+m,I});
}
bool operator<(const edge&w)const{return c<w.c;}
}es[];
int ws[][];
void maxs(int&a,int b){if(a<b)a=b;}
int main(){
scanf("%d%d",&n,&m);
for(int i=;i<=m*;++i)f[i]=f2[i]=i;
for(int i=;i<=n;++i)ps[i].R();
for(int i=;i<=m;++i)es[i].R(i);
scanf("%d",&q);
for(int i=;i<=q;++i){
qs[i][].R();
qs[i][].R();
e[ep++]=(ev){,qs[i][].x,i};
e[ep++]=(ev){,qs[i][].x,i};
}
std::sort(e,e+ep);
e[ep].x=e[ep-].x+;
double x0=e[].x-,x1;
for(int i=,j=;i<ep;){
x1=e[i].x;
for(;j<ep&&e[j].x==x1;++j);
X=(x0+x1)/.;
for(;i<j&&e[i].t==;++i){
std::set<ln>::iterator it=line.find(es[e[i].w].l);
line.erase(it);
}
X=(x1+e[j].x)/.;
for(int k=i;k<j&&e[k].t==;++k){
ln w=es[e[k].w].l;
line.insert(w);
}
for(;i<j&&e[i].t==;++i){
ln w=es[e[i].w].l;
std::set<ln>::iterator it=line.find(w);
++it;
if(it==line.end())merge(,e[i].w+m);
else merge(e[i].w+m,it->id);
--it;
if(it==line.begin())merge(,e[i].w);
else --it,merge(e[i].w,it->id+m);
}
X=x1;
for(;i<j;++i){
ln w=(ln){,qs[e[i].w][e[i].t-].y,};
std::set<ln>::iterator it=line.lower_bound(w);
if(it!=line.end())ws[e[i].w][e[i].t-]=it->id;
}
x0=x1;
}
for(int i=;i<=n;++i)if(!vs[i].empty()){
std::sort(vs[i].begin(),vs[i].end());
vs[i].push_back(vs[i][]);
for(int j=;j<vs[i].size();++j){
merge(vs[i][j-].i2,vs[i][j].i1);
}
}
std::sort(es+,es+m+);
for(int i=;i<=m;++i){
int x=get2(get(f,es[i].ID));
int y=get2(get(f,es[i].ID+m));
if(x&&y&&x!=y){
if(h2[x]<h2[y])f2[x]=y,ee[x]=es[i].c;
else{
if(h2[x]==h2[y])++h2[x];
f2[y]=x;ee[y]=es[i].c;
}
}
}
for(int i=;i<=q;++i){
int x=get(f,ws[i][]),y=get(f,ws[i][]);
if(!x||!y)puts("-1");
else{
int v=;
while(x!=y){
if(h2[x]>h2[y])std::swap(x,y);
maxs(v,ee[x]);
x=f2[x];
}
printf("%d\n",v);
}
}
return ;
}

bzoj3051: [wc2013]平面图的更多相关文章

  1. bzoj3051[WC2013]平面图(树上倍增+平面图转对偶图+扫描线)

    简要题意:二维平面上n个点,点之间有一些连线,连线不在点之外的地方相交,将平面分为若干个区域.给出一些询问点对,问从这个点所在的区域走到另一个点所在的区域的最小代价. 题解:这道题首先可以把平面图转对 ...

  2. [WC2013]平面图——平面图点定位

    [WC2013]平面图 码农题 平面图点定位: 1.平面图转对偶图:[HNOI2016]矿区 2.扫描线点定位 把所有的顶点和询问点排序,扫描线 每个边在fr的位置加入,to的位置删除,竖直直线不要 ...

  3. 【uoj57】 WC2013—平面图

    http://uoj.ac/problem/57 (题目链接) 题意 给出二位平面上n个点,点之间有一些连线,连线不在顶点之外的地方相交,将平面分为若干个区域.给出一些询问点对,问从这个点所在的区域走 ...

  4. 洛谷 P4073 [WC2013]平面图

    #include<bits/stdc++.h> using namespace std; ; typedef long double LD; ; ); int dcmp(LD x){ret ...

  5. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  6. [BZOJ1997][HNOI2010] 平面图判定

    Description Input Output     是的..BZOJ样例都没给.     题解(from 出题人): 如果只考虑简单的平面图判定,这个问题是非常不好做的. 但是题目中有一个条件— ...

  7. 【BZOJ 3051】【UOJ #57】【WC 2013】平面图

    http://www.lydsy.com/JudgeOnline/problem.php?id=3051 http://uoj.ac/problem/57 这道题需要平面图转对偶图,点定位,最小生成树 ...

  8. 【BZOJ-2007】海拔 最小割 (平面图转对偶图 + 最短路)

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2095  Solved: 1002[Submit][Status] ...

  9. 【BZOJ-4423】Bytehattan 并查集 + 平面图转对偶图

    4423: [AMPPZ2013]Bytehattan Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 144  Solved: 103[Submit][ ...

随机推荐

  1. php大力力 [052节] php数据库页面修改功能

    php大力力 [052节] php数据库页面修改功能

  2. clojure 之 hello world

    1. 安装Leiningen 2. lein new app bar 3. lein run Hello, World!

  3. Tips for VNCServer config

    Tips for VNCServer After the ClearCase server reboot by Jingwei, my vncserver background process is ...

  4. DIV+CSS布局网站基本框架

    html代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  5. 兼容解决 IE 、火狐、谷歌浏览器中 Iframe框架的页面缓存的方法

    <script type="text/javascript"> document.write('<iframe src="/ad_footer.html ...

  6. 库函数API和C语言汇编语言混合式编程

    C语言代码内嵌汇编的方法: 在C语言文件中以如下格式加入汇编代码 __asm__( “汇编语句模板” :输出部分 :输入部分 :“破坏描述部分” ) asm可以由__asm__代替,为其别名. 可加上 ...

  7. 用UltraEdit软件替换回车换行的窍门

    转载:http://www.zhuantilan.com/jiqiao/46518.html 方法/步骤 1.打开一个原始文档,在文档中各个人物名称是以逗号分隔的,我们下面来尝试把逗号替换为换行符. ...

  8. DotNetBar 第2课,窗口设置 Ribbon Form 样式

    1. 新增 windows 窗体时,选 Ribbon Form 2. 窗体继承 Office2007RibbonForm 3. 设计窗口下面,删除 删除styleManager1  组件 窗口效果如下 ...

  9. stunnel-client

    #!/bin/bash # giving user passwordless sudo privileges USER=`whoami` MYPATH=$(cat /etc/passwd|grep $ ...

  10. 不就ideas嘛,谁没有!

    20160214 survey of current RDF triple storage systems survey of semantic web stack inference mechani ...