当前位置: 首页 > news >正文

淮安住房和城乡建设厅网站原画培训机构哪里好

淮安住房和城乡建设厅网站,原画培训机构哪里好,天津葛沽 网站建设公司,做眼镜网站草图有什么原则[NOI2002] 银河英雄传说 题目背景 公元 580158015801 年,地球居民迁至金牛座 α\alphaα 第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展。 宇宙历 799799799 年,银河系的两大军…

[NOI2002] 银河英雄传说

题目背景

公元 580158015801 年,地球居民迁至金牛座 α\alphaα 第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展。

宇宙历 799799799 年,银河系的两大军事集团在巴米利恩星域爆发战争。泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌。

题目描述

杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气。在这次决战中,他将巴米利恩星域战场划分成 300003000030000 列,每列依次编号为 1,2,…,300001, 2,\ldots ,300001,2,,30000。之后,他把自己的战舰也依次编号为 1,2,…,300001, 2, \ldots , 300001,2,,30000,让第 iii 号战舰处于第 iii 列,形成“一字长蛇阵”,诱敌深入。这是初始阵形。当进犯之敌到达时,杨威利会多次发布合并指令,将大部分战舰集中在某几列上,实施密集攻击。合并指令为 M i j,含义为第 iii 号战舰所在的整个战舰队列,作为一个整体(头在前尾在后)接至第 jjj 号战舰所在的战舰队列的尾部。显然战舰队列是由处于同一列的一个或多个战舰组成的。合并指令的执行结果会使队列增大。

然而,老谋深算的莱因哈特早已在战略上取得了主动。在交战中,他可以通过庞大的情报网络随时监听杨威利的舰队调动指令。

在杨威利发布指令调动舰队的同时,莱因哈特为了及时了解当前杨威利的战舰分布情况,也会发出一些询问指令:C i j。该指令意思是,询问电脑,杨威利的第 iii 号战舰与第 jjj 号战舰当前是否在同一列中,如果在同一列中,那么它们之间布置有多少战舰。

作为一个资深的高级程序设计员,你被要求编写程序分析杨威利的指令,以及回答莱因哈特的询问。

输入格式

第一行有一个整数 TTT1≤T≤5×1051 \le T \le 5 \times 10^51T5×105),表示总共有 TTT 条指令。

以下有 TTT 行,每行有一条指令。指令有两种格式:

  1. M i jiiijjj 是两个整数(1≤i,j≤300001 \le i,j \le 300001i,j30000),表示指令涉及的战舰编号。该指令是莱因哈特窃听到的杨威利发布的舰队调动指令,并且保证第 iii 号战舰与第 jjj 号战舰不在同一列。

  2. C i jiiijjj 是两个整数(1≤i,j≤300001 \le i,j \le 300001i,j30000),表示指令涉及的战舰编号。该指令是莱因哈特发布的询问指令。

输出格式

依次对输入的每一条指令进行分析和处理:

  • 如果是杨威利发布的舰队调动指令,则表示舰队排列发生了变化,你的程序要注意到这一点,但是不要输出任何信息。
  • 如果是莱因哈特发布的询问指令,你的程序要输出一行,仅包含一个整数,表示在同一列上,第 iii 号战舰与第 jjj 号战舰之间布置的战舰数目。如果第 iii 号战舰与第 jjj 号战舰当前不在同一列上,则输出 −1-11

样例 #1

样例输入 #1

4
M 2 3
C 1 2
M 2 4
C 4 2

样例输出 #1

-1
1

提示

战舰位置图:表格中阿拉伯数字表示战舰编号

带权并查集
我一开始的代码:

#include <bits/stdc++.h>using namespace std;const int maxn=30000;int pre[maxn+5],d[maxn+5],lazy[maxn+5],num[maxn+5],ind[maxn+5];
int T;
char op;void init()
{for(int i=0;i<=maxn;i++){pre[i]=i;d[i]=0;lazy[i]=0;num[i]=1;ind[i]=0;}
}int findroot(int x)
{if(pre[x]==x) return x;int y= pre[x];int rooty=findroot(y);d[x]+= lazy[y];lazy[x]+= lazy[y];if(--ind[y]==0){lazy[y]=0;}pre[x]=rooty;ind[rooty]++;return rooty;
}
void join(int x,int y)
{int rootx=findroot(x);int rooty=findroot(y);pre[rootx]=rooty;d[rootx]+=num[rooty];lazy[rootx]+=num[rooty];num[rooty]+=num[rootx];ind[rooty]++;
}void query(int x,int y)
{int rootx=findroot(x);int rooty=findroot(y);if (rootx!=rooty){puts("-1");return;}int maxi=max(d[x],d[y]);int mini=min(d[x],d[y]);printf("%d\n", max(maxi-mini-1,0) );}
int main()
{int x,y;while(~scanf("%d",&T)){init();while(T--){scanf(" %c%d%d",&op,&x,&y);if(op=='M'){join(x,y);}else if(op=='C'){query(x,y);}}}return 0;
}

看了题解,发现不用使用lazy数组。
因为d[]维护的是当前结点相对于根结点的距离。
每个结点x的d[x]初始化时是0,只有一次机会作为根结点合并到其它根结点rooty,此时d[x]会有更新。
同时当x的父亲节点y=pre[x]指向新的父结点时,会更新d[y],之后调用findroot(x)也会更新d[x]。

#include<iostream>
#include<cmath>
using namespace std;
int f[30001],s[30001],b[30001];
int find(int o)//查找
{if(f[o]==o) return o;int k=f[o];f[o]=find(f[o]);//路径压缩s[o]+=s[k];//更新当前节点到根的距离return f[o];
}
int main()
{int n;cin>>n;for(int i=1;i<=30000;i++) {f[i]=i;s[i]=0;b[i]=1;}for(int i=1;i<=n;i++){char ch;int x,y,dx,dy;cin>>ch>>x>>y;if(ch=='M'){dx=find(x);//查找x的根dy=find(y);//查找y的根f[dx]=dy;//把x放在y后面s[dx]+=b[dy];//更新x的根到新的根的距离b[dx]+=b[dy];//更新集合大小b[dy]=b[dx];//更新集合大小}if(ch=='C'){dx=find(x);dy=find(y);if(dx!=dy){cout<<-1<<endl;continue;}//不在同一个集合中cout<<abs(s[x]-s[y])-1<<endl;//中间战舰的数量等于x到根的距离减y到根的距离减一。}}return 0;
}

总结:

  1. 使用并查集,当一个结点x指向的结点变化时pre[x]
    无非一下两种情况: 1) x作为根结点 合并到 另一个树的根结点。
  1. x或其子树内结点调用查找操作,将x指向了根结点rootx。
http://www.15wanjia.com/news/7214.html

相关文章:

  • 长沙网站建设 个人百度seo排名规则
  • 网站页面优化方案青岛网站推广系统
  • 郑州 互联网 公司网站免费的自媒体一键发布平台
  • 房产集团网站建设做个网站
  • 网站建设大学seo伪原创工具
  • 网站聚合怎么做互联网营销师含金量
  • 视频网站外链怎么做如何推广一个新的app
  • 加强司法机关网站建设江苏网站seo设计
  • 做房产网站有哪些广告策划公司
  • 软件自学网站哪个合肥seo好
  • 网站建设找星火龙今日头条新闻最全新消息
  • 高端h5手机网站设计案例怎样制作属于自己的网站
  • seo怎么做网站优秀案例建网站哪个平台好
  • html5做测试网站的源代码app拉新推广接单平台
  • 凡科可以做返利网站吗成品短视频app下载有哪些软件
  • 如何用dw做网站首页百度推广登录官网入口
  • 定制专业网站免费优化推广网站的软件
  • 西安做网站收费价格elo机制
  • 常州网站建设价位seo研究中心超逸seo
  • 网站重新安装深圳百度推广公司
  • 如何来做网站外贸建站
  • 建设公司需要网站吗全球搜官网
  • 做警员编号网站网站推广网站
  • 网站注册时间查询酒店网络营销方式有哪些
  • 做违法网站判刑吗排名优化服务
  • java做网站和php做网站6淘宝关键词优化怎么弄
  • 做网站武汉bt鹦鹉磁力
  • 郑州做网站哪个公司好百度广告投放公司
  • 国内优秀网页设计网站百度一下官网搜索引擎
  • 网站制作多久能完成win10优化大师官网