最新要闻
- 当前热议!神似梅西男子成网红 被民众围堵合影:这也太像了
- 分析师称《阿凡达2》难以回本:卡梅隆标准定太高了
- 2199元 掌阅Smart Air Pro电纸书上架:8寸大屏、300PPI显示
- 天天即时:怀旧情怀拉满:宾得宣布将开发新款胶片相机
- 阿根廷夺冠“拯救”伊利 但“奶茅”光环渐黯
- 环球快讯:一加宣布与OPPO服务融合:12月底全面加入OPPO售后服务系统
- 东北将迎今冬以来最强降雪:持续时间最长、范围最广
- PCIe 5.0 SSD终于满血了!读写都是14GB/s、容量8TB
- 热消息:蔚来遭遇225万美元数据勒索 官方声明
- 当前讯息:铃木“大G”!吉姆尼五门版无伪谍照:最多能塞进7个人
- 奇迹!女子手机从26楼掉落未摔坏 真身竟是这款手机
- 5499元 联合创新推出新款32英寸显示器:4K MiniLED屏、144Hz高刷
- “非洲之王”拥抱新技术:传音首台折叠屏手机已通过蓝牙SIG认证
- 天天短讯!世界北极熊之都升温过快 已危及北极熊生存:吃不上饭了
- 即时看!1月1日起:澳门私家车可经港珠澳大桥出入内地
- 观速讯丨巡游大巴太高 梅西险些撞上电缆!他带回阿根廷的大力神杯居然是复制品
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
热资讯!Codeforces 1763 F Edge Queries 题解
【资料图】
题目链接
先观察满足题目中给出的限制的图有什么特点。先看\(C_u\),它指的是所有与\(u\)在同一个简单环内的节点。发现一个点v在\(C_u\)中,当且仅当\(u,v\)点双连通。关于点双连通的判断。首先必要性是显然的,不点双连通显然不行。至于充分性,可以把\(u\)作为根跑出dfs树,根据上面点双连通的判断方法,此时u和v之间的树上路径中的每一个点一定至少有1条非树边"跨过"(除了u和v)。至于跨过的定义,下图中左边的红点被跨过了,而右边的没有。
然后,u和v在一个简单环中等价于:以u为原点、v为汇点,每条边能双向走、容量为1,此时u到v的最大流\(\ge 2\)。由于最大流等于最小割,证明最小割\(\ge 2\)即可。很容易发现不可能只割掉1条边使uv不连通,所以原命题得证。
那么\(S_u=C_u\)又说明什么呢?再来看看上面链接里判断点双连通的方法,其中有些树边被加进了同一个连通块中,不妨看成把一些树边染成了相同的颜色,没有非树边跨过的边没有被染颜色,则所有同色边连接的所有点是属于同一个点双连通分量的。这题中\(S_u=C_u\)其实说明了不能有一个点同时属于两个点双连通分量,也就是不能有两条都被染色但颜色不同的树边挨在一起。如果一个点u同时属于两个分量,那显然这两个分量中所有的点都在\(C_u\)中,但无法找到一个很长的简单环同时包括这两个分量的所有点。所以这就说明了输入的图长这样:一些由同色边连成的点双连通分量,之间用树边(同时也是桥边)连成一棵树。在这种情况下,点双分量和边双分量是一样的,边双比较好写,所以可以用边双的方法来把所有分量处理出来。
现在处理出所有的分量了,来看回答询问。首先u和v之间的原图桥边肯定是不能删的。把每个分量看成一个点建一棵新树,令U表示u所在的分量缩成的点,V同理。则U~V路径上某一些点代表的分量中的所有边能被删掉。对于路径中间一个不是U也不是V的点,它代表的分量中的边能被删取决于:
对于端点U和V的分量来说也是一样的,但是需要分类讨论。统计答案维护每个点到根的和就行了,询问的时候求一下LCA,然后相减。维护的时候细节比较多,但是都不难想。
时间复杂度\(O(nlogn)\)。
点击查看代码
#include #define rep(i,n) for(int i=0;i#define fi first#define se second#define mpr make_pair#define pb push_backvoid fileio(){ #ifdef LGS freopen("in.txt","r",stdin); freopen("out.txt","w",stdout); #endif}void termin(){ #ifdef LGS std::cout<<"\n\nEXECUTION TERMINATED"; #endif exit(0);}using namespace std;int n,m,add[200010],dep[200010];vector e,g[200010],tg[200010];bool vis[200010],isBri[200010];void dfs(int pos,int par){ vis[pos]=true; rep(i,g[pos].size()) if(g[pos][i].fi!=par) { if(!vis[g[pos][i].fi]) tg[pos].pb(g[pos][i]),dep[g[pos][i].fi]=dep[pos]+1,dfs(g[pos][i].fi,pos); else if(dep[g[pos][i].fi]-1) isBri[lst]=true;}int fa[200010],ecnt[200010];vector v[200010];int Find(int x){return fa[x]==x ? x:fa[x]=Find(fa[x]);}vector > ng[200010];int root,dep2[200010],fa2[200010][23],sum[200010];map consum;pii fae[200010];void dfs3(int pos,int par,int dd,int becon=-1){ dep2[pos]=dd;fa2[pos][0]=par; rep(i,ng[pos].size()) if(ng[pos][i].fi!=par) { sum[ng[pos][i].fi]=sum[pos]; if(becon!=-1&&becon!=ng[pos][i].se.fi) sum[ng[pos][i].fi]+=ecnt[pos]; dfs3(ng[pos][i].fi,pos,dd+1,ng[pos][i].se.se); } else fae[pos]=ng[pos][i].se;}int getLCA(int x,int y){ for(int i=19;i>=0;--i) if(fa2[x][i]>0&&dep2[fa2[x][i]]>=dep2[y]) x=fa2[x][i]; for(int i=19;i>=0;--i) if(fa2[y][i]>0&&dep2[fa2[y][i]]>=dep2[x]) y=fa2[y][i]; if(x==y) return x; for(int i=19;i>=0;--i) if(fa2[x][i]!=fa2[y][i]) x=fa2[x][i],y=fa2[y][i]; return fa2[x][0];}int getFa(int x,int y){ for(int i=19;i>=0;--i) if(y&(1<>n>>m; int x,y; rep(i,m) { scanf("%d%d",&x,&y); g[x].pb(mpr(y,i));g[y].pb(mpr(x,i)); e.pb(mpr(x,y)); } dfs(1,0); dfs2(1); repn(i,n) fa[i]=i; rep(i,m) if(!isBri[i]) { ++ecnt[e[i].fi];++ecnt[e[i].se]; if(Find(e[i].fi)!=Find(e[i].se)) fa[Find(e[i].fi)]=Find(e[i].se); } repn(i,n) v[Find(i)].pb(i); repn(i,n) if(v[i].size()) rep(j,v[i].size()) if(v[i][j]!=i) ecnt[i]+=ecnt[v[i][j]]; rep(i,m) if(isBri[i]) { x=Find(e[i].fi);y=Find(e[i].se); ng[x].pb(mpr(y,e[i]));ng[y].pb(mpr(x,mpr(e[i].se,e[i].fi))); consum[mpr(x,y)]=consum[mpr(y,x)]=e[i].fi+e[i].se; } root=Find(1); dfs3(root,0,0); rep(i,20) repn(j,n) fa2[j][i+1]=fa2[fa2[j][i]][i]; int q; cin>>q; rep(qn,q) { scanf("%d%d",&x,&y); if(x==y) { puts("0"); continue; } int xx=x,yy=y; x=Find(x);y=Find(y); if(x==y) { printf("%d\n",ecnt[x]/2); continue; } if(dep2[x]>dep2[y]) swap(x,y),swap(xx,yy); int lca=getLCA(x,y); if(lca==x) { int nlca=getFa(y,dep2[y]-dep2[x]-1); int ans=sum[y]-sum[nlca]; if(fae[y].fi!=yy) ans+=ecnt[y]; if(fae[nlca].se!=xx) ans+=ecnt[x]; printf("%d\n",ans/2); } else { int xlca=getFa(x,dep2[x]-dep2[lca]-1),ylca=getFa(y,dep2[y]-dep2[lca]-1); int ans=sum[x]+sum[y]-sum[xlca]-sum[ylca]; if(fae[xlca].se!=fae[ylca].se) ans+=ecnt[lca]; if(fae[x].fi!=xx) ans+=ecnt[x]; if(fae[y].fi!=yy) ans+=ecnt[y]; printf("%d\n",ans/2); } } termin();}
热资讯!Codeforces 1763 F Edge Queries 题解
天天视讯!如何使用Yum History查找已安装或已删除的软件包信息
天天新消息丨混合场景
当前热议!神似梅西男子成网红 被民众围堵合影:这也太像了
分析师称《阿凡达2》难以回本:卡梅隆标准定太高了
2199元 掌阅Smart Air Pro电纸书上架:8寸大屏、300PPI显示
前端工程化Vue-cli
天天微头条丨Python unittest数据处理ddt
前端CSS Flex布局8大重难点知识,收藏起来吧
世界新消息丨django10 分页器与Form组件
【全球新要闻】FreeSWITCH学习笔记:XML配置文件
天天即时:怀旧情怀拉满:宾得宣布将开发新款胶片相机
阿根廷夺冠“拯救”伊利 但“奶茅”光环渐黯
环球快讯:一加宣布与OPPO服务融合:12月底全面加入OPPO售后服务系统
东北将迎今冬以来最强降雪:持续时间最长、范围最广
世界速递!框架第九课---ajax补充说明,多对多三种创建方式,django内置序列化组件(drf前身),ORM批量操作数据(ORM操作优化),自定义分页器,f
WPF工控组态软件之温度计
每日播报!Iceberg在袋鼠云的探索及实践
每日关注!hibernate validate工具,小心你的姿势不对
PCIe 5.0 SSD终于满血了!读写都是14GB/s、容量8TB
热消息:蔚来遭遇225万美元数据勒索 官方声明
当前讯息:铃木“大G”!吉姆尼五门版无伪谍照:最多能塞进7个人
奇迹!女子手机从26楼掉落未摔坏 真身竟是这款手机
5499元 联合创新推出新款32英寸显示器:4K MiniLED屏、144Hz高刷
“非洲之王”拥抱新技术:传音首台折叠屏手机已通过蓝牙SIG认证
天天短讯!世界北极熊之都升温过快 已危及北极熊生存:吃不上饭了
天天热资讯!深度学习炼丹-数据处理和增强
世界热门:记录--可视化大屏-用threejs撸一个3d中国地图
Python操作Excel(openpyxl)
全球热点评!Html5 canvas创意特效合集
即时看!1月1日起:澳门私家车可经港珠澳大桥出入内地
观速讯丨巡游大巴太高 梅西险些撞上电缆!他带回阿根廷的大力神杯居然是复制品
天天短讯!中国联通科技人才占比已达30% 曾发话不能再用老眼光看电信行业
空难曾致346人死亡 波音737 Max飞机延期采用最新安全标准
每日观察!广州多个外卖平台下单后配送慢 平台:员工已是全负荷工作
世界视讯!数据结构堆(Heap)&排序&二叉树
今日播报!用好这个任务管理工具,轻松躲避职场明枪暗箭
世界今日报丨彩虹女神跃长空,Go语言进阶之Go语言高性能Web框架Iris项目实战-登录与图形验证码(captcha)EP06
今日热闻!低代码:如何成为企业业务价值提升的一大利器?
热消息:Intel第二代独立显卡1年后见:要追上RTX 4070!
主页不刷新了 小红书崩了累坏网友:WiFi、流量疯狂切换
罗永浩称他的失败不是理想主义的错 是他们自己的错
世界热讯:吴京《流浪地球2》吃苹果皮:大年初一上映
世界要闻:中国移动千兆宽带用户已达2.4亿!你是其中之一吗?
安全信息流工具-中文安全RSS小程序
supervisor+gunicorn+uvicorn部署fastapi项目
天天实时:四年保质期囤货无压力!900压缩饼干8斤85元
天天热资讯!iPhone 15系列或重新划分机型组合:14 Plus太拉胯 要大改
一加11质感绝了!刘作虎给员工秀真机:围观群众都发出WOW
美国“显卡税”又推迟9个月:一旦征收 最多涨价25%
全球讯息:大无语 车主称理想L9半个月坏三次 充电口从电动变手动
天天关注:企业转型难?火山引擎数智平台提供数智升级新路径
焦点热门:Dubbo架构设计与源码解析(一) 架构设计
Redis的AOF持久化
【报资讯】防火墙功能(锐捷安全篇)
当前热文:多方安全计算(4)MPC万能积木:秘密共享
【全球时快讯】多方安全计算(3)MPC万能钥匙:混淆电路
全力推进企业数智赋能发展主线,低代码任重道远
天天要闻:linux安装stable diffusion2.0完整教程-还不会安装sd2.0?一篇文章教会你AI绘画
焦点速读:proto IDL管理工具buf使用实践
P2329 栅栏
全球观点:Xml转Java实体类对象 xml转Javabena 对象 且多级嵌套 复杂嵌套
世界动态:用Python写一个一次性计算出加减乘除的运算小程序
世界热文:实验一:获取主机信息
全球播报:MySQL-InnoDB磁盘结构
今日热议:pkg对egg项目打包
天天精选!java的final关键字
环球快报:【验证码逆向专栏】某片滑块、点选验证码逆向分析
环球热议:别再用 JWT 作为 Session 系统了,问题重重,后果很危险!
全球球精选!Osx10.14升级watchman踩坑记
时讯:二分法
用Python来写个小型购物车程序
天天观速讯丨基于 Dubbo Admin 动态进行流量隔离
赫德-德普官司以一百万美元赔偿和解
百度地图首发自研“北斗高精”技术 升级“真”车道级导航
【环球时快讯】中国版“猛禽”!长城山海炮大型皮卡实车现身:配自研3.0T、9AT
上海首张城市高级辅助驾驶地图许可来了 百度率先获批
环球快看点丨伊朗男子65厘米创吉尼斯最矮纪录:站起来才到到成人膝盖处
热门:如何基于 Spring Boot 快速开发一个 Dubbo 微服务应用
【世界时快讯】安卓抄错了?iPhone 15 Pro最新概念图:告别纯直边
当前关注:网络谣言别再传了!短视频中梅西抱的不是母亲:是阿根廷队女厨师
天天通讯!微软、谷歌之后 欧盟反垄断又对美国Meta下手:可罚款上百亿美元
每日视讯:4K游戏串流没了 NVIDIA删除使用9年的GameStream功能引用户不满
2022最后一跌!今起油价下调:加满一箱92号汽油少花19.5元
消息!苹果App Store被法国罚款100万美元:Epic CEO、扎克伯格都曾痛批
多次骂新能源!丰田再度质疑汽车全面电动化:中国品牌弯道超车
35岁本泽马宣布从法国队退役:球迷唏嘘 祝福俱乐部继续精彩
Python单元测试框架unittest
环球播报:北京等多地天空疑现震撼的火箭夜光云:原理科普
年出货3亿只、逛店必买的一次性碱性电池:被宜家正式停售了
环球新资讯:抖音在世界杯上下的功夫 远不止撒币10亿买版权这么简单
差评如潮!《三体》动画评分暴跌至6.4:网友"口吐芬芳"
快讯:Epic与美国FTC和解:36.6亿元摆平两起官司
Spring IOC官方文档学习笔记(二)之Bean概述
焦点观察:FreeSWITCH学习笔记:通道变量
焦点关注:32开书本大小!华硕新款12代酷睿i7迷你机PC发布:零噪音
环球即时:内蒙古上空巨大发光体划破天际 网友:像手电筒一样
192个框框的怪兽!AMD Zen4线程撕裂者7000来了
世界快报:Django框架:9、Ajax简介、基本语法、数据编码格式、携带文件数据
马斯克现身世界杯观战阿根廷对法国:赛后发出灵魂拷问