HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge(Set,线段树)

HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge

Solution

我们考虑维护在环上的边的个数,答案就是总边数减去环上边数。

环的形态是这样的:(0,l),(0,l+1)...(0,r),(1,r),(1,r−1)...(1,l)(0,l),(0,l+1)...(0,r),(1,r),(1,r-1)...(1,l)(0,l),(0,l+1)...(0,r),(1,r),(1,r1)...(1,l)
考虑怎样才会连成环,显然是上下两段连续的横边加上它们之间的纵边。因此横坐标在[l,r][l,r][l,r]之间的点在同一个环上的必要条件是[l,r][l,r][l,r]之间的横边都存在。

因此我们可以用setsetset维护上下两段连续的横边都存在的极长连续段[l,r][l,r][l,r]。然后对于[l,r][l,r][l,r]之间的纵边,我们找到该区间内最左边的纵边mnmnmn和最右边的纵边mxmxmx以及总纵边个数numnumnum。那么这个极长连续段的环边个数为2(mx−mn)+num2(mx-mn)+num2(mxmn)+num,且因为我们维护的是极长连续段,因此总环边个数就是所有极长连续段的环边个数之和,不会算重。

对于mn,mx,nummn,mx,nummn,mx,num,直接用线段树维护即可。
时间复杂度O(mlgn)O(mlgn)O(mlgn)

注意n=1n=1n=1的情况可能会算出−1-11来!(虽然评测数据没有这种情况)
注意题中给定的坐标(x1,y1),(x2,y2)(x1,y1),(x2,y2)(x1,y1),(x2,y2),可能存在y1>y2y1>y2y1>y2的情况!!!

Code

#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <queue>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cctype>
#include <string>
#include <cstring>
#include <ctime>
#include <cassert>
#include <string.h>
//#include <unordered_set>
//#include <unordered_map>
//#include <bits/stdc++.h>#define MP(A,B) make_pair(A,B)
#define PB(A) push_back(A)
#define SIZE(A) ((int)A.size())
#define LEN(A) ((int)A.length())
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define fi first
#define se secondusing namespace std;template<typename T>inline bool upmin(T &x,T y) { return y<x?x=y,1:0; }
template<typename T>inline bool upmax(T &x,T y) { return x<y?x=y,1:0; }typedef long long ll;
typedef unsigned long long ull;
typedef long double lod;
typedef pair<int,int> PR;
typedef vector<int> VI;const lod eps=1e-11;
const lod pi=acos(-1);
const int oo=1<<30;
const ll loo=1ll<<62;
const int mods=924844033;
const int MAXN=200005;
const int INF=0x3f3f3f3f;//1061109567
/*--------------------------------------------------------------------*/
inline int read()
{int f=1,x=0; char c=getchar();while (c<'0'||c>'9') { if (c=='-') f=-1; c=getchar(); }while (c>='0'&&c<='9') { x=(x<<3)+(x<<1)+(c^48); c=getchar(); }return x*f;
}
set<PR> Set;
int flag[MAXN],n,m,ans;
struct Node
{ Node(){}Node(int mn,int mx,int sum):mn(mn),mx(mx),sum(sum){};friend Node operator + (Node a,Node b) { return Node(min(a.mn,b.mn),max(a.mx,b.mx),a.sum+b.sum); }int mn,mx,sum; 
} s[MAXN<<2];
void Build(int x,int l,int r)
{if (l==r) { s[x]=Node(l,l,1); return; }int mid=(l+r)>>1;Build(x<<1,l,mid);Build(x<<1|1,mid+1,r);s[x]=s[x<<1]+s[x<<1|1];
}
void Update(int x,int l,int r,int y,int z)
{if (l==r) { s[x]=(z==-1?Node(INF,0,0):Node(l,l,1)); return; }int mid=(l+r)>>1;if (y<=mid) Update(x<<1,l,mid,y,z);else Update(x<<1|1,mid+1,r,y,z);s[x]=s[x<<1]+s[x<<1|1];
}
Node Query(int x,int l,int r,int L,int R)
{if (l>=L&&r<=R) return s[x];int mid=(l+r)>>1;if (R<=mid) return Query(x<<1,l,mid,L,R);else if (L>mid) return Query(x<<1|1,mid+1,r,L,R);else return Query(x<<1,l,mid,L,mid)+Query(x<<1|1,mid+1,r,mid+1,R);
}int update(int x,int opt)
{if (x<1||x>n) return 0;set<PR>::iterator it=Set.lower_bound(MP(x+1,0));if (it==Set.begin()||(--it)->se<x) return 0;Node t=Query(1,1,n,it->fi,it->se+1);if (t.sum<=1) return 1;ans-=((t.mx-t.mn)*2+t.sum)*opt;return 1;
}
void add(int x)
{set<PR>::iterator it=Set.lower_bound(MP(x+1,0));PR t=MP(x,x),L=MP(0,0),R=MP(0,0);if (it!=Set.end()&&it->fi==x+1) R=*it;if (it!=Set.begin()&&(--it)->se==x-1) L=*it;if (R.fi) Set.erase(Set.find(R)),t.se=R.se;if (L.fi) Set.erase(Set.find(L)),t.fi=L.fi;Set.insert(t);
}
void erase(int x)
{set<PR>::iterator it=Set.lower_bound(MP(x+1,0));PR t=*(--it);Set.erase(it);if (t.fi<x) Set.insert(MP(t.fi,x-1));if (t.se>x) Set.insert(MP(x+1,t.se));
}signed main()
{int Case=read();while (Case--){n=read(),m=read(),ans=(n==1);Build(1,1,n);Set.clear(),Set.insert(MP(1,n));for (int i=1;i<n;i++) flag[i]=2;while (m--){int opt=read(),x1=read(),y1=read(),x2=read(),y2=read();if (y1>y2) swap(y1,y2);ans+=(opt==1)?1:-1;if (opt==1&&x1==x2&&(++flag[y1])==2) update(y1-1,-1),update(y1+1,-1),add(y1),update(y1,1);if (opt==2&&x1==x2&&(--flag[y1])==1) update(y1,-1),erase(y1),update(y1-1,1),update(y1+1,1);if (y1==y2){if (!update(y1,-1)) update(y1-1,-1);Update(1,1,n,y1,(opt==1)?1:-1);if (!update(y1,1)) update(y1-1,1);}printf("%d\n",ans);}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315561.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #704 (Div. 2) E. Almost Fault-Tolerant Database 思维

传送门 题意&#xff1a; 给nnn个长度为mmm的数组&#xff0c;要求构造一个长度为mmm的数组&#xff0c;使得这个数组与前面nnn个数组同一位置最多两个元素不同。 思路&#xff1a; 我们为了方便构造&#xff0c;可以先把要构造的数组看成nnn个数组的第一个数组&#xff0c;让…

Asp.net core使用MediatR进程内发布/订阅

1、背景最近&#xff0c;一个工作了一个月的同事离职了&#xff0c;所做的东西怼了过来。一看代码&#xff0c;惨不忍睹&#xff0c;一个方法六七百行&#xff0c;啥也不说了吧&#xff0c;实在没法儿说。介绍下业务场景吧&#xff0c;一个公共操作A&#xff0c;业务中各个地方…

[APIO2018] New Home 新家(线段树,二分答案,离散化)

[APIO2018] New Home 新家 Solution 对于时间轴我们直接离散化扫描线&#xff0c;维护每一个商店的加入和删除。 对于询问(x,t)(x,t)(x,t)&#xff0c;不好直接回答&#xff0c;这里的关键一步是&#xff1a;我们要求的是kkk种商店最小距离的最大值&#xff0c;于是考虑二分…

Codeforces Round #701 (Div. 2) C. Floor and Mod 数学分块

传送门 题意&#xff1a; 给两个数x,yx,yx,y。现在你计算有多少对a(a<x)a(a<x)a(a<x)和b(b<y)b(b<y)b(b<y)使得⌊ab⌋amodb\left \lfloor \frac{a}{b} \right \rfloora\bmod b⌊ba​⌋amodb。 思路&#xff1a; 因为xxx和yyy都是1e91e91e9的范围&#xff0…

AGC011D - Half Reflector(模拟)

AGC011D - Half Reflector Solution 先考虑改变一次。 我们令LLL表示往左走的球&#xff0c;RRR表示往右走的球&#xff0c;xxx表示任意种类的球&#xff0c;(−x)(-x)(−x)表示与xxx相反种类的球。 当球处于ARAARAARA的状态&#xff08;即有一个向右的球在两个AAA机器人之间…

[开源] FreeSql.Tools Razor 生成器

FreeSql 经过半年的开发和坚持维护&#xff0c;在 0.6.x 版本中完成了几大重要事件&#xff1a;1、按小包拆分&#xff0c;每个数据库实现为单独 dll&#xff1b;2、实现 .net framework 4.5 支持&#xff1b;3、同时支持 MySql.Data、MySqlConnector 的实现&#xff1b;4、自定…

Codeforces Round #701 (Div. 2) D. Multiples and Power Differences 思维构造

传送门 题意&#xff1a; 给定一个矩阵aaa&#xff0c;让你构造一个矩阵bbb&#xff0c;要求矩阵bbb的每个元素是aaa对应位置元素的倍数&#xff0c;且矩阵bbb的每两个相邻元素相差为k4(k>1)k^4(k>1)k4(k>1)。注意aaa的元素范围是1<a<161<a<161<a<…

AGC012D - Colorful Balls(并查集)

AGC012D - Colorful Balls Solution 连边题。 找出www最小的球yyy和www最小且颜色和yyy不同的球zzz。 yyy向所有colt̸coly,wtwy≤Ycol_t\not col_y,w_tw_y\leq Ycolt​​coly​,wt​wy​≤Y的球ttt连边。zzz向所有colt̸coly,wtwz≤Ycol_t\not col_y,w_tw_z\leq Ycolt​…

WebAssembly和Blazor:解决了一个存在十年的老问题

本文要点WebAssembly 是一种新的客户端技术&#xff0c;可以在所有现代浏览器&#xff08;包括移动浏览器&#xff09;中实现近乎原生的性能&#xff0c;而且不需要插件。许多语言&#xff0c;包括 C、C#、Go 和 Rust&#xff0c;都可以编译成面向基于栈的 WebAssembly 虚拟机的…

Educational Codeforces Round 103 (Rated for Div. 2) D. Journey dp

传送门 题意&#xff1a; 给n1n1n1个点&#xff0c;每两个点之间有一个字符L(表示i1连向i)L(表示i1连向i)L(表示i1连向i)或者R(表示i连向i1)R(表示i连向i1)R(表示i连向i1)&#xff0c;每秒可以移动一次&#xff0c;每移动一次每两个点之间的方向会互换&#xff0c;问每个点能到…

LG P4074 [WC2013] 糖果公园(带修莫队,树上莫队)

LG P4074 [WC2013] 糖果公园 Solution 树上带修莫队&#xff0c;主要还是复习带修莫队和树上莫队。 带修莫队&#xff1a; 带修莫队要先对lll分块的序号作为第一关键字&#xff0c;对rrr分块的序号作为第二关键字&#xff0c;时间ttt作为第三关键字排序&#xff0c;然后正常…

《电商后台系统产品逻辑解析》学习笔记

文是我阅读《电商产品经理宝典&#xff1a;电商后台系统产品逻辑全解析》一书的学习笔记&#xff0c;为后续我司做家居电商后台系统储备相关领域的业务知识。一、支撑线后台概览“前端用户的一小步&#xff0c;后台系统的一大步”&#xff0c;平时常见的功能如购物车、优惠券等…

P3403 跳楼机 同余最短路

传送门 题意&#xff1a; 思路&#xff1a; 转换一下题目就是用若干x,y,zx,y,zx,y,z能凑出来多少个<h<h<h的数。先考虑两个数y,zy,zy,z的情况&#xff0c;我们如果能求出来这两个数能凑出来的数设为sumsumsum&#xff0c;让后sumkx<hsumkx<hsumkx<h求出来…

LG P4899 [IOI2018] werewolf 狼人(kruskal重构树,二维数点)

LG P4899 [IOI2018] werewolf 狼人 Solution 我们发现010101限制长这样子&#xff1a; ∃x(minids−>x≥L&maxidx−>e≤R)→1\exist_x(min_{id_{s->x}}\geq L\;\;\And\;\;max_{id_{x->e}}\leq R) \to 1∃x​(minids−>x​​≥L&maxidx−>e​​≤R)…

NopCommerce 4.2的安装与运行

、关于NopCommerceNopCommerce是国外ASP.Net领域一个高质量的B2C开源电商项目&#xff0c;最新版本4.2基于ASP.NET Core MVC 2.2和EF Core 2.2开发&#xff0c;其强大的功能特性和插件机制使其成为了.NET领域开源电商项目的标杆。当然&#xff0c;还有一些其他的开源电商项目如…

P1527 [国家集训队]矩阵乘法 整体二分 + 二维树状数组

传送门 题意&#xff1a; 思路&#xff1a; 算是个整体二分的板子啦&#xff0c;不过这个是二维的矩阵&#xff0c;我们只需要把一位树状数组改成二维的&#xff0c;让后动态维护单点加&#xff0c;区间查询前缀和即可。 //#pragma GCC optimize(2) #include<cstdio>…

应用性能问题解决实际案例

某项目在上线前的APT&#xff08;Application Performance Testing应用程序性能测试&#xff09;过程中发现性能问题&#xff0c;性能测试结果影响是否上线&#xff0c;紧急求助外部项目组技术专家。因分属不同项目&#xff0c;只能通过项目组提供的信息进行分析。第一轮评审现…

BZOJ#3786. 星系探索(平衡树,fhq-treap,弱化版ETT)

BZOJ#3786. 星系探索 Solution 子树加&#xff0c;换fatherfatherfather&#xff08;保证还是树&#xff09;&#xff0c;询问到根路径和。 树上路径求和不好动态维护&#xff0c;于是转化到序列上&#xff0c;维护一个括号序&#xff0c;dfndfndfn处贡献为www&#xff0c;fn…

Worker Service in ASP .NET Core

介绍提到 ASP.NET Core&#xff0c;我们多半会想到 ASP.NET MVC、ASP.NET Web API、Razor page 及 Blazor。随着 .NET Core 3.0 的推出&#xff0c;今天会介绍一个全新推出的功能&#xff1a;Work Service 。我们可以在 Visual Studio 2019 中通过预定的项目模版快速创建一个 W…

Codeforces Round #693 (Div. 3) G. Moving to the Capital dp + 思维

传送门 题意&#xff1a; 给一个图&#xff0c;111号点为中心点&#xff0c;定义dis[i]dis[i]dis[i]表示111号点到iii的距离。现在有三种移动方式 (1)(1)(1)从iii移动到jjj且dis[i]<dis[j]dis[i]<dis[j]dis[i]<dis[j]。 (2)(2)(2)从iii移动到jjj且dis[i]>dis[j]dis…