csp-s模拟测试58「Divisors」·「Market」·「Dash Speed」
A. Divisors
B. Market
可以把时间离线下来,
考试没有想到将询问离线,用数组存算了算只能过200的点,拿了70
事实上背包后直接二分就好。。。
C. Dash Speed
好题,想到以前的一道题影子。
考场用单调队列多QJ了20分,然而没有想到并查集
线段树上分治?????
线段树上的节点表示在该权值在该区间内的边,每个节点开个vector即可
那么考虑区间查询和单点修改,
对于每个叶子节点,我们从上到下所经历的边其实就是可行的边
对于每个节点维护并查集,该联通块的最长直径和两个端点
在两个联通块相连时就是6种情况
即原直径或两联通块的端点所连的直径
但是对于每个点我们清空并查集会T,
那么我们采用按秩合并....
就是对每个节点编个排名,然后排名小的连向排名的节点,
然后我们开个栈,记录每次新连边后更改信息
void deld(int now){
while(top>now){
fa[st[top].to]=st[top].to;
del[st[top].fa]-=del[st[top].to];
len[st[top].fa]=st[top].val;
lx[st[top].fa]=st[top].dian1;
rx[st[top].fa]=st[top].dian2;
top--;
}
}
因为我们是将两联通块的fa节点相连,所以撤去后,儿子节点指向自己,父亲节点的del要减去
然后len,及直径两端点修改回原来的。
然后以为是栈,所以分治完后清空就好了。
因为倍增LCA超时了,所以改为ST求LCA,O(1)查询,跑的飞快
void DFS(int x,int father){
pre[++dep]=x;R[dep]=deep[x];fir[x]=dep;
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==father)continue;
deep[to]=deep[x]+1;
DFS(to,x);
pre[++dep]=x;R[dep]=deep[x];
}
}
void ST(){
logg[0]=-1;
for(int i=1;i<=dep;++i)logg[i]=logg[i>>1]+1;
for(int j=1;j<=dep;++j)faa[j][0]=j;
for(int j=1;(1<<j)<=dep;++j){
for(int i=1;i+(1<<j)-1<=dep;++i){
int x=faa[i][j-1];int y=faa[i+(1<<(j-1))][j-1];
if(R[x]<R[y])faa[i][j]=x;
else faa[i][j]=y;
}
}
}
每个节点遍历时添进pre数组里,回溯时也要添R数组记录深度,fir记录每个值的最小出现位置
倍增找两节点中深度最小的节点,注意现在节点是pre的序列节点
查询找fir[x],fir[y]这段区间的最小深度对应的节点
csp-s模拟测试58「Divisors」·「Market」·「Dash Speed」的更多相关文章
- [考试反思]1003csp-s模拟测试58:沉淀
稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...
- [CSP-S模拟测试58]题解
以后题解还是单独放吧. A.Divisors 根号筛求所有数的因子,扫一遍去重统计即可. #include<cstdio> #include<iostream> #includ ...
- NOIP模拟测试19「count·dinner·chess」
反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...
- 「题解」NOIP模拟测试题解乱写II(36)
毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...
- csp-s模拟测试94
csp-s模拟测试94 一场简单题,打爆了.$T1$脑抽分解质因数准备分子分母消,想了半天发现$jb$互质直接上天,果断码了高精滚蛋.$T2$无脑手玩大样例,突然灵光一闪想到映射到前$K$大小的区间, ...
- 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 Eureka的高可用需要 ...
- Android单元测试与模拟测试详解
测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...
- [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)
目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
随机推荐
- 接口测试原理及Postman详解
接口测试定义 接口是前后端沟通的桥梁,是数据传输的通道,包括外部接口.内部接口.内部接口又包括:上层服务与下层服务接口,同级接口 生活中常见接口:电脑上的键盘.USB接口,电梯按钮,KFC下单 接口测 ...
- c语言编程学习之二维数组
二维数组 c语言按照行主序存储二维数组.也就是说,二维数组元素在内存中的位置是连续的,每行末尾元素(若不是最后一行)的下一个元素就是下一行的首元素. 如下图所示 接下来我们来分析一下如何将二维数组所有 ...
- PageHelper简单使用
PageHelper的简单使用 先引入对应的依赖 <dependency> <groupId>com.github.pagehelper</groupId> < ...
- 段间跳转之TSS段
TR寄存器,TSS描述符,TSS段 TR寄存器与普通的段寄存器一样都有可见部分和不可见部分.TR的可见部分为16位为其段选择子,不可见部分是32位的TSS基地址和16位的大小. TSS描述符存在GDT ...
- [源码解析] 并行分布式框架 Celery 之 容错机制
[源码解析] 并行分布式框架 Celery 之 容错机制 目录 [源码解析] 并行分布式框架 Celery 之 容错机制 0x00 摘要 0x01 概述 1.1 错误种类 1.2 失败维度 1.3 应 ...
- BUAA-OO-第三单元总结
面向对象第三单元JML总结 JML理论基础及工具链梳理 JML语言理论基础 JML语言是对于JAVA进行规格化设计的一种表述语言,他能以一种统一化语言,逻辑性强的格式,向程序设计者描述这一方法实现的功 ...
- Mybatis-plus在原有的select查询语句中动态追加查询条件
一.适用场景 1.使用了xml形式的mapper.2.不想在select查询中大量使用<if>标签来判断条件是否存在而加入条件. 二.步骤 1.自定义wrapper继承QueryWrapp ...
- 关于文字内容过长,导致文本内容超出html 标签宽度的解决方法之自动换行
在标签的style 属性中设置 word-break style="word-break:break-all;" 这样就可以实现换行 上截图没设置之前 设置之后 完美解决!!!!! ...
- 基于Hadoop集群搭建Hive安装与配置(yum插件安装MySQL)---linux系统《小白篇》
用到的安装包有: apache-hive-1.2.1-bin.tar.gz mysql-connector-java-5.1.49.tar.gz 百度网盘链接: 链接:https://pan.baid ...
- 最全的go语言的时间格式
该文可以快速在Go语言中获得时间的计算. 在Go中获取时间 如何获取当前时间 now := time.Now() fmt.Printf("current time is :%s", ...