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直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
随机推荐
- mongo中常用的命令
命令使用mongo shell 执行 1.mongo中增加新字段 mongo shell 进入后执行use table选中要添加字段的库 db.getCollection('表名').update({ ...
- SSM久别遇新坑
SSM久别遇新坑 久别个锤子,也就几天没看,改bug改到怀疑人生 maven的父子模块问题 众所周知,用maven建立一个空的模块,在它之下,将原本的各层次结构分别新建为一个子模块,就能够将各业务进行 ...
- 【tee小白的第一篇随笔】keystone代码略读
武大信安在读,最近在自学Risc-v架构的可信执行环境. (实验报告多半是为了交差.临时起意写写博客,分享一些自己读代码的心得理解.) 本篇内容由队和我友总结而成,如有错误欢迎指正交流. keysto ...
- 【敏杰开发】Scrum Meeting 博客汇总
敏杰开发团队 Scrum Meeting 博客汇总 项目名称:[知识路书] 一.Alpha阶段 Scrum meeting 1 2020/04/07 选题 Scrum meeting 2 2020/0 ...
- 7. IDEA概述和安装
1.1IDEA概述 IDEA全称InteliJ IDEA,是用于Java语言开发的继承环境,它是业界公认的目前用于Java程序开发的最好工具 集成环境:把代码编写,编译,执行,调试等多种功能综合到一起 ...
- mysql登录框注入绕过单引号匹配
0x00 原理 网站使用正则匹配对用户名一栏传到服务器的参数进行了匹配,如果匹配到了单引号则报错 0x01 简单例子 当我们输入admin'时,网站直接报错,很有可能就是用了正则,这样我们也不 ...
- WPS-插入-公式-菜单 怎样在EXCEL中使用PRODUCT函数
怎样在EXCEL中使用PRODUCT函数 ################ WPS2018 -插入-公式-[专门有公式菜单] 插入函数 ################## ...
- shell中 -eq,-ne,-gt,-lt,-ge,-le数字比较符
使用说明: -eq //equals等于 -ne //no equals不等于 -gt //greater than 大于 -lt //less than小于 -ge ...
- 002.Python数据类型
一 python语言注释 就是对代码的解释, 方便大家阅读代码用的 1.1 注释的分类 (1)单行注释 # print 在python2.x print "1" # print 在 ...
- Centos6.9以下查看端口占用情况和开启端口命令
Centos查看端口占用情况命令,比如查看80端口占用情况使用如下命令: lsof -i tcp:80 列出所有端口 netstat -ntlp 1.开启端口(以80端口为例) ...