网上基本上找不到这道题,何况LJJ还稍微改了一下......

原题:传送门

题目描述

ljj 被S 国数不清的漂亮小姐姐所吸引,为了搞清楚为什么S 国有如此多的漂亮小姐姐,他决定研究S 国的历史。

根据S 国史书的记载,在史书记载前,S 国有n 个城市(城市编号0~n-1),它们彼此之间都没有道路相连,但一个城市内是联通的。

每一年,在位的国王会在城市x,y 之间修建一条双向道路,一条道路可能被修建多次,但修建双向道路的起点和终点不会是同一个城市。

而在这之间,国王会计划进行若干次旅行。对于计划进行的一次旅行st->ed,

如果当时能完成这次旅行。而t 年前不能完成这次旅行,国王会对之前的建设成果感到满意,

否则他会很生气,并改变接下来所有计划修建的道路,即让实际修建的道路的x,y 更换为(x+c)%n,(y+c)%n,

生气状态持续到下一次旅行开始,旅行的起点和终点可能是同一个城市。

当然这些年中也发生了若干次国王的交替,初始国王的c 值为0,而之后每个国王的c 值不一定相同。

一个国王在位期间,他的c 值不会改变,刚登基的国王处于不生气的状态。

请根据史书帮助ljj 得出国王对于每次旅行是否满意,如果你全部分析正确的话,他说不定会给你介绍一个漂亮的小姐姐呢。

输入

本题含有多组测试数据!

对于每组数据第一行两个整数n,m 表示城市数和史书记载的内容数。

接下来m 行,每行是以下三种格式之一:

1.K c,表示国王交替,以及新国王的c 值(含义如题目所述)。

2.R x y,表示国王计划在x,y 之间修建一条双向道路,但可能会因为国王生气,并不会在x,y 之间修建道路,具体见题目描述。

3.T st ed t,表示国王计划进行一次从st 到ed 的旅行,且比较的是t 年前的情况(国王可能会史书开始记载以前的情况比较)。

注意只有遇到R 操作才会使实际年份+1。

输出

对于每个T 操作输出一行,如果国王满意输出Y,否则输出N。

样例输入1

3 7

R 0 1

T 0 1 1

K 1

R 0 1

T 0 1 1

R 0 1

T 0 2 1

样例输出1

Y

N

Y

数据范围与约定

对于30%的数据,1<=n<=1000,1<=m<=3000。

另30%数据满足没有任何国王交替。

对于100%的数据,满足1<=n,m<=3*10^5,0<= v,x,y,st,ed <n,0<= t <m。

数据有一定梯度,每个测试点数据组数<=3

题解

这道题做法有很多。

我第一眼看还以为是可持久化并查集,果断打了暴力......

显然可以离线做,但是这道题仅仅是修改强制在线。

如果是询问也强制在线,就不能离线做了。

正解其实是并查集按秩合并。

由于是按秩合并,每个点的父亲只会被修改一次(从它自己变成另一个点)。

所以记录一下父亲被更改的时间。

找祖先的时候,给一个时间限制y,如果t[i]>y,则那个连接实际上在y时间下是不存在的,就不能继续向上找了。

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; int n,m,c,yr,ang;
int f[];
int sz[];
int t[]; int read()
{
char c=getchar();int ret=;
while(c<''||c>'')c=getchar();
while(c>=''&&c<='')ret=ret*+c-'',c=getchar();
return ret;
} int findfa(int p,int y)
{
while(f[p]!=p&&t[p]<=y)p=f[p];
return p;
} int main()
{
freopen("history.in","r",stdin);
freopen("history.out","w",stdout);
while(scanf("%d%d",&n,&m)!=EOF)
{
c=yr=ang=;
for(int i=;i<n;i++)f[i]=i,sz[i]=,t[i]=;
for(int i=;i<=m;i++)
{
char op[];
scanf("%s",op+);
if(op[]=='K')
{
ang=;
c=read();
}
if(op[]=='R')
{
int x=read(),y=read();
if(ang)x=(x+c)%n,y=(y+c)%n;
yr++;
x=findfa(x,yr),y=findfa(y,yr);
if(x==y)continue;
if(sz[x]<sz[y])swap(x,y);
f[y]=x;
sz[x]+=sz[y];
t[y]=yr;
}
if(op[]=='T')
{
int x=read(),y=read(),tt=read();
int nx=findfa(x,yr),ny=findfa(y,yr);
int px=findfa(x,yr-tt),py=findfa(y,yr-tt);
if(px!=py&&nx==ny)printf("Y\n"),ang=;
else printf("N\n"),ang=;
}
}
}
fclose(stdin);
fclose(stdout);
return ;
}

History

18.09.22模拟赛T2 历史的更多相关文章

  1. 18/9/21模拟赛-Updated

    18/9/21模拟赛 期望得分:100:实际得分:0  qwq 拿到题目第一眼,我去,这不是洛谷原题(仓鼠找Sugar)吗 又多看了几眼,嗯,对,除了是有多组数据外,就是原题 然后码码码....自以为 ...

  2. 模拟赛T2 交换 解题报告

    模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...

  3. EZ 2018 03 09 NOIP2018 模拟赛(三)

    最近挺久没写比赛类的blog了 链接:http://211.140.156.254:2333/contest/59 这次的题目主要考验的是爆搜+打表的能力 其实如果你上来就把所有题目都看过一次就可以知 ...

  4. 20180530模拟赛T2——绀碧之棺

    题目背景 qiancl 得到了一张藏宝图,上面写了一道谜题. 题目描述 定义\(F(n)\)为 n 在十进制下各个数位的平方和,求区间\([a,b]\)中有多少\(n\)满足\(k\times F(n ...

  5. 2019.11.11 模拟赛 T2 乘积求和

    昨天 ych 的膜你赛,这道题我 O ( n4 ) 暴力拿了 60 pts. 这道题的做法还挺妙的,我搞了将近一天呢qwq 题解 60 pts 根据题目给出的式子,四层 for 循环暴力枚举统计答案即 ...

  6. 20161005 NOIP 模拟赛 T2 解题报告

    beautiful 2.1 题目描述 一个长度为 n 的序列,对于每个位置 i 的数 ai 都有一个优美值,其定义是:找到序列中最 长的一段 [l, r],满足 l ≤ i ≤ r,且 [l, r] ...

  7. 20161003 NOIP 模拟赛 T2 解题报告

    Weed duyege的电脑上面已经长草了,经过辨认上面有金坷垃的痕迹. 为了查出真相,duyege 准备修好电脑之后再进行一次金坷垃的模拟实验. 电脑上面有若干层金坷垃,每次只能在上面撒上一层高度为 ...

  8. NOIP欢乐模拟赛 T2 解题报告

    小澳的坐标系 (coordinate.cpp/c/pas) [题目描述] 小澳者表也,数学者景也,表动则景随矣. 小澳不喜欢数学,可数学却待小澳如初恋,小澳睡觉的时候也不放过. 小澳的梦境中出现了一个 ...

  9. 2019.03.09 ZJOI2019模拟赛 解题报告

    得分: \(20+0+40=60\)(\(T1\)大暴力,\(T2\)分类讨论写挂,\(T3\)分类讨论\(40\)分) \(T1\):天空碎片 一道神仙数学题,貌似需要两次使用中国剩余定理. 反正不 ...

随机推荐

  1. 虚函数重载(overwrite) 继承覆盖问题

    引言 类接口需要添加默认参数,以适应不同情况调用, 但是clang-tidy 不允许在接口上设置默认参数,ps: 可能担心继承类里接口重新设置新默认参数而导致误用的情况 #include <st ...

  2. JavaEE--分布式与集群

    参考:https://www.zhihu.com/question/20004877 集群是个物理形态,分布式是个工作方式. 只要是一堆机器,就可以叫集群,他们是不是一起协作着干活,这个谁也不知道:一 ...

  3. MySQL笔记(一)

    MySQL是目前最流行的关系型数据库管理系统之一,它是由MySQL AB公司开发.发布并支持.MySQL是一个跨平台的开源关系型数据库管理系统,被广泛地应用在internet上的中小型网站开发中.相比 ...

  4. 第一行代码近期bug及解决

    Android学习笔记(5)----启动 Theme.Dialog 主题的Activity时程序崩溃的解决办法https://www.cnblogs.com/dongling/p/6476308.ht ...

  5. Python笔记_第三篇_面向对象_8.对象属性和类属性及其动态添加属性和方法

    1. 对象属性和类属性. 我们之前接触到,在类中,我们一般都是通过构造函数的方式去写一些类的相关属性.在第一次介绍类的时候我们把一些属性写到构造函数外面并没有用到构造函数,其实当时在写的时候,就是在给 ...

  6. Python笔记_第二篇_面向过程_第二部分_1.函数

    函数:这个词属于一个数学概念,在编程语言借鉴了这个概念,表现形式是一段程序代码的组合,也叫“程序集”.有过编程基础的人很容易理解这个概念,当我们编写程序越来越多的时候,程序设计大师们会把散乱的程序进行 ...

  7. HTTP知识整理

    HTTP协议 HTTP协议的主要特点可概括如下: 1.支持客户/服务器模式. 2.简单快速:客户向服务器请求服务时,只需传送请求方法和路径.请求方法常用的有GET.HEAD.POST.每种方法规定了客 ...

  8. 吴裕雄--天生自然 pythonTensorFlow图形数据处理:读取MNIST手写图片数据写入的TFRecord文件

    import numpy as np import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_dat ...

  9. CSS 定位体系概述

    三种定位体系简介 框( box )布局影响因素之一,便是定位体系.定位体系也是其最为重要的影响因素. CSS2.1 中,一个框可以根据三种定位体系布局.CSS2.1 中的定位体系帮助作者使他们的文档更 ...

  10. tc/traffic control 网络控制工具

    第一个例子 增加延时 tc qdsic add dev enp0s3 root netem delay 200ms qdisc : queuing discipline, 当内核需要发送包到某个接口时 ...