P1196 ssl1225-银河英雄传说【图论,并查集】

正题

题目链接:
https://www.luogu.org/problemnew/show/P1196


大意

有30000列和30000个飞船,开始时i号飞船在i列上。有两种操作:
(1)将x所在的列上的所有飞船连接在y号飞船所在的列上
(2)询问x号飞船与y号飞船之间相隔几个飞船


解题思路

用两个数组分别储存离它祖先的距离和后面的飞船数量(包括上自己)。然后在寻找祖先压缩路线时重新计算离他祖先的距离,然后用前缀和求相隔的飞船数。


代码

#include<cstdio>
using namespace std;
int father[30001],behind[30001],front[30001];
int n,q,x,y;
char c;
int abs(int x)
{if (x<0) return -x;else return x;
}
int find(int x)
{if (father[x]==x) return x;int lf=find(father[x]);front[x]+=front[father[x]];//下传标记return father[x]=lf;
}//寻找祖先
int unionn(int x,int y)
{int fa=find(x),fb=find(y);father[fa]=fb;front[fa]=behind[fb];behind[fb]+=behind[fa];
}//连接两点
int main()
{scanf("%d",&q);n=30000;for (int i=1;i<=n;i++){father[i]=i;front[i]=0;behind[i]=1;}//初始化for (int i=1;i<=q;i++){scanf("\n%c %d %d",&c,&x,&y);if (c=='M'){unionn(x,y);//连接}if (c=='C'){if (find(x)!=find(y)) printf("-1\n");else{printf("%d\n",abs(front[x]-front[y])-1);//输出}}}
}

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

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

相关文章

Java程序员必看的 13 本 Java 书籍

转载自 Java程序员必看的 13 本 Java 书籍 关乎于程序员&#xff0c;除了做项目来提高自身的技术&#xff0c;还有一种提升自己的专业技能就是&#xff1a;多&#xff01;看&#xff01;书&#xff01; 毕竟&#xff0c;书是学习的海洋呢&#xff01;So&#xff0c;Java程序…

python常见内置函数

abs # 求绝对值 all #Return True if bool(x) is True for all values x in the iterable.If the iterable is empty, return True. any #Return True if bool(x) is True for any x in the iterable.If the iterable is empty, return False. ascii #Return an ASCII-on…

祝你生日快乐!

祝生日快乐今天&#xff0c;于我来说是个特别的日子。本来&#xff0c;我是比较低调的&#xff0c;尤其是对于生日来说&#xff0c;可以说是这些年都没有好好的过过&#xff0c;要么忘记了&#xff0c;要么就是在异国他乡的&#xff0c;谁都不识&#xff0c;这一天和往常的一天…

P1892-团伙【图论,并查集】

正题 题目链接&#xff1a; https://www.luogu.org/problemnew/show/P1892 大意 两个人如果认识就只有两种关系&#xff0c;敌人或朋友 而&#xff1a; 朋友的朋友是朋友 敌人的敌人是朋友 &#xff08;敌人之间也可能是敌人&#xff09; 求团伙总数 解题思路 就像做食…

.NET Exceptionless 日志收集框架本地环境搭建

一、简介 Exceptionless 是一个开源的实时的日志收集框架&#xff0c;它可以应用在基于 ASP.NET&#xff0c;ASP.NET Core&#xff0c;Web Api&#xff0c;Web Forms&#xff0c;WPF&#xff0c;Console&#xff0c;MVC 等技术栈的应用程序中&#xff0c;并且提供了Rest接口可以…

Redis 常用操作命令,非常详细

转载自 Redis 常用操作命令&#xff0c;非常详细 下面总结并演示了 Redis 的 常用管理命令、key 操作、字符串、集合、列表、散列类型的操作命令。 你需要掌握的 Redis 知识 史上最全 Redis 高可用解决方案总结 为什么分布式一定要有Redis? Spring Boot Redis Cluster 实…

java中如何对汉字进行排序?

前言&#xff1a;上一篇文章我们讲解了java中实现Comparator进行排序 和实现Comparable进行排序&#xff0c;我们分别举例根据学号和姓名降序排序&#xff0c;原文在这里&#xff1a;java中如何对对象排序&#xff1f; &#xff0c;不过在文章的最后&#xff0c;我故意留了个问…

Blazor将.NET带回到浏览器

由Steve Sanderson开发的Blazor尝试使用WebAssembly和DotNetAnywhere将.NET带回到浏览器。它不是要成为一个像Flash或Silverlight那样的完整生产框架&#xff0c;而是要探索一下有什么可能性。 WebAssembly将自己描述成一个“内存安全的沙箱执行环境”标准&#xff0c;它“甚至…

ssl2342-打击犯罪【并查集】

正题 大意 有n个犯罪团伙&#xff0c;他们之间可以相互联系&#xff0c;按照1到n的顺序打击&#xff0c;求最少打击多少个犯罪团伙可以使多个犯罪团伙组成的已经无法与外联系的团伙最大的那个不超过n/2。 解题思路 先储存每条连接的路径&#xff0c;然后从n枚举到1&#xff0…

Java 必须掌握的 12 种 Spring 常用注解

转载自 Java 必须掌握的 12 种 Spring 常用注解 1.声明bean的注解 Component 组件&#xff0c;没有明确的角色 Service 在业务逻辑层使用&#xff08;service层&#xff09; Repository 在数据访问层使用&#xff08;dao层&#xff09; Controller 在展现层使用&#xff…

过滤器和监听器

文章目录01 过滤器的简介02 使用过滤器进行乱码解决03 使用过滤器进行登陆的控制04 过滤器更多内容05 监听器实现日志记录06 监听器实现在线人数的统计07 其他监听器使用01 过滤器的简介 为什么使用过滤器&#xff1f; 我们目前书写项目中遇到的问题&#xff1f; A、目前使用的…

高启航:秋运会!

本文原创&#xff1a;高启航&#xff08;本文所有收益均归高启航所有&#xff09;在十月份的二十一号&#xff0c;我们济南信息工程学校迎来了一年一度的秋季运动会。这次秋运会&#xff0c;每一个班级所准备的开幕式、训练已久的千人武术大展演、以及在运动会上表现优越的运动…

用python画出吉祥物

大前提 你需要一个"npy" 效果图 源码 # 库的导入 import turtleturtle.title(PythonBingDwenDwen&#xff08;axing&#xff09;) #这里的字我们可以自己进行修改turtle.speed(10) # 速度&#xff0c;如果觉得20快了&#xff0c;你们可以设置10# 左手 turtle.p…

RabbitMQ知多少

1.引言 RabbitMQ——Rabbit Message Queue的简写&#xff0c;但不能仅仅理解其为消息队列&#xff0c;消息代理更合适。RabbitMQ 是一个由 Erlang 语言开发的AMQP&#xff08;高级消息队列协议&#xff09;的开源实现&#xff0c;其内部结构如下&#xff1a; RabbitMQ作为一个…

分布式系统中处理参数配置的 4 种方案

转载自 分布式系统中处理参数配置的 4 种方案 一个系统中包含有各种各样的配置信息&#xff0c;如一个日志文件需要配置以下几个信息。 日志文件生成主目录 日志文件名称&#xff0c;不同的日志级别对应不同的文件 当前日志级别 还有其他各种业务参数、系统参数等&#x…

P1455-搭配购买【图论,并查集,dp,背包】

正题 题目链接&#xff1a; https://www.luogu.org/problemnew/show/P1455 大意 有n个商品&#xff0c;给出价值和价格。有m组搭配&#xff0c;如果买了其中一个就得买另一个&#xff0c;给出你拥有的钱&#xff0c;求能获得的最大价值 解题思路 首先用并查集算出每个搭配的…

王宝兴:秋运会

本文原创&#xff1a;王宝兴本文所有收益归王宝兴所有一年一度的运动会如期而至。可谓是“沙场秋点兵”的壮阔&#xff0c;给了我们难以言喻的激情。为了入场式&#xff0c;为了我们每个人&#xff0c;为了我们整个班集体&#xff0c;所有人付出的不止一点&#xff0c;在这短短…

.NET Core快速入门教程 1、开篇:说说.NET Core的那些事儿

一、.NET Core的诞生 聊 .NET Core&#xff0c;就不得不说他的爸爸 .NET。当年Java刚刚兴起&#xff0c;如火如荼&#xff0c;微软也非常推崇Java&#xff0c;当时Windows平台的Java虚拟机就是微软按照JVM标准实现的&#xff0c;据说也是当时性能最好的Java虚拟机。但是微软也…

P2814-家谱【图论,并查集,std map库】

正题 题目链接&#xff1a; https://www.luogu.org/problemnew/show/P2814 大意 有n个父子关系&#xff08;可能不止一个孩子&#xff09;&#xff0c;询问一些人最大的祖先 代码 #include<cstdio> #include<map> #include<string> #include<iostream…