news 2026/5/1 6:11:47

P14978 [USACO26JAN1] Mooclear Reactor S题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
P14978 [USACO26JAN1] Mooclear Reactor S题解

[USACO26JAN1] Mooclear Reactor S

思路

将限制建双向边,设一个联通块的根为r t rtrt,则每个a i a_iai一定可以表示为a i = k × a r t + b a_i=k\times a_{rt}+bai=k×art+b,其中k ∈ { − 1 , 1 } k\in \left \{ -1,1 \right \}k{1,1}。如果有环,那么每个a i a_iai的值就确定了,检查一下有多少a i a_iai产生动力即可。否则我们解出满足l i ≤ a i ≤ r i l_i\le a_i \le r_iliairia r t a_{rt}art取值范围。现在问题转换为:有若干线段,求一个点使包含这个点的线段数量最多。扫描线即可,时间复杂度O ( n log ⁡ n ) O(n\log_{}{n})O(nlogn),瓶颈在于排序。

代码

压行导致代码有点猎奇。

#include<bits/stdc++.h>usingnamespacestd;constintN=2e5+5;intt,n,m,cnt,l[N],r[N],tp[N],k[N],to[N<<1],nxt[N<<1],w[N<<1];voidadd(intx,inty,intz){to[++cnt]=y,w[cnt]=z,nxt[cnt]=tp[x],tp[x]=cnt;}boolbj[N],bjj[N],flag;longlongb[N],val;voidbfs(intx){queue<int>q;q.push(x),bj[x]=1,b[x]=0,k[x]=1,val=1000000000000000;while(!q.empty()){intx=q.front();q.pop();for(inti=tp[x];i;i=nxt[i])if(!bj[to[i]])b[to[i]]=w[i]-b[x],k[to[i]]=-k[x],bj[to[i]]=1,q.push(to[i]);elseif(!(k[to[i]]+k[x])&&b[to[i]]+b[x]!=w[i]||(k[to[i]]+k[x])&&(w[i]-b[x]-b[to[i]])%(k[x]+k[to[i]])||(k[to[i]]+k[x])&&val!=1000000000000000&&val!=(w[i]-b[x]-b[to[i]])/(k[x]+k[to[i]]))flag=1;elseif(k[to[i]]+k[x])val=(w[i]-b[x]-b[to[i]])/(k[x]+k[to[i]]);}}vector<pair<longlong,int>>sol;voiddfs1(intx){longlongll=k[x]==1?l[x]-b[x]:b[x]-r[x],rr=k[x]==1?r[x]-b[x]:b[x]-l[x];bjj[x]=1,sol.push_back({ll,1}),sol.push_back({rr+1,-1});for(inti=tp[x];i;i=nxt[i])if(!bjj[to[i]])dfs1(to[i]);}intdfs2(intx){bjj[x]=1;longlongv=k[x]*val+b[x];intsiz=(v>=l[x]&&v<=r[x]);for(inti=tp[x];i;i=nxt[i])if(!bjj[to[i]])siz+=dfs2(to[i]);returnsiz;}intmain(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>t;while(t--){cnt=flag=0;cin>>n>>m;for(inti=1;i<=n;i++)cin>>l[i];for(inti=1;i<=n;i++)cin>>r[i];while(m--){intx,y,z;cin>>x>>y>>z;add(x,y,z),add(y,x,z);}intans=0;for(inti=1;i<=n;i++)if(!bj[i]){bfs(i);if(val==1000000000000000){dfs1(i),sort(sol.begin(),sol.end());intsum=0,max1=0;for(intj=0;j<sol.size();j++)sum+=sol[j].second,max1=max(max1,sum);ans+=max1,sol.clear();}elseans+=dfs2(i);}cout<<(flag?-1:ans)<<"\n";for(inti=1;i<=n;i++)tp[i]=bj[i]=bjj[i]=0;}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 16:16:15

大数据时代,ETL 如何助力数据挖掘

大数据时代&#xff0c;ETL 如何助力数据挖掘&#xff1a;从“脏数据”到“金矿”的转化密码 一、引言&#xff1a;数据挖掘的“拦路虎”——脏数据与分散数据 1.1 数据挖掘工程师的崩溃瞬间 你有没有遇到过这样的场景&#xff1f; 想做用户行为分析&#xff0c;却发现数据…

作者头像 李华
网站建设 2026/5/1 4:53:01

Java毕设选题推荐:基于springboot的个性化音乐推荐系统基于用户音乐个性化推荐系统【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/1 5:44:35

【计算机毕业设计案例】基于springboot的演出网站订票系统基于SpringBoot+vue的演出购票系统(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/23 18:42:32

python基于yolov5深度学习的苹果叶片病虫害图像识别系统

前言   随着农业现代化进程的加速&#xff0c;果园管理中对苹果叶片病虫害的精准识别与及时防治需求日益迫切。传统的人工检测方法依赖专业知识和经验&#xff0c;存在效率低、误判率高、易受环境干扰等问题。基于YOLOv5深度学习的苹果叶片病虫害图像识别系统&#xff0c;通过…

作者头像 李华
网站建设 2026/5/1 5:44:40

Java计算机毕设之基于SpringBoot + Vue的电子产品手机数码销售系统基于springboot的电子产品电子外设销售系统(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华