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直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
随机推荐
- php实现微信推送消息
一.<?phpnamespace Org\Weixin;class OrderPush{ protected $appid; protected $secrect; protected $acc ...
- springboot开发浅谈 2021/05/11
学习了这么久,本人希望有时间能分享一下,这才写下这篇浅谈,谈谈软件,散散心情. 这是本人的博客园账号,欢迎关注,一起学习. 一开始学习springboot,看了好多网站,搜了好多课程.零零落落学了一些 ...
- Docker安装教程(超详细)
Docker安装教程(超详细) 欢迎关注博主公众号「Java大师」, 专注于分享Java领域干货文章, 关注回复「资源」, 免费领取全网最热的Java架构师学习PDF, 转载请注明出处 http:// ...
- OOP第三章博客
OO第三单元博客 • (1)梳理JML语言的理论基础.应用工具链情况: 理论基础: 网络资料上面介绍JML有两种主要的用法: 开展规格化设计.这样交给代码实现人员的将不是可能带有内在模糊性.二义性的自 ...
- OO随笔之魔鬼的第一单元——多项式求导
OO是个借助Java交我们面向对象的课,可是萌新们总是喜欢带着面向过程的脑子去写求导,然后就是各种一面(main)到底.各种方法杂糅,然后就是被hack的很惨. 第一次作业:萌新入门面向对象 题目分析 ...
- 使用PuTTY连接Azure VM
使用PuTTY连接Azure VMhtml { -webkit-print-color-adjust: exact } * { box-sizing: border-box; -webkit-prin ...
- [刷题] PTA 02-线性结构1 两个有序链表序列的合并
程序: 1 #include <stdio.h> 2 #include <stdlib.h> 3 4 typedef int ElementType; 5 typedef st ...
- Ubuntu 20.04 配置多网卡链路聚合
Ubuntu 20.04 配置多网卡链路聚合 多网卡IP配置 首先查看网卡信息 root@it:~# ip add 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65 ...
- 014.Ansible Playbook Role 及调试
一 role 简介 在ansible中,role是将playbook分割为多个文件的主要机制,大大简化了复杂的playbook的编写,同时已与复用 role各个目录的作用及可用文件 files:存放由 ...
- Linux 文件隐藏属性-创建文件默认权限
Linux特殊权限介绍 # password原本只有root可以访问但是为什么普通用户在修改密码的时候也可以改里面的内容. [root@gong ~]# ll /usr/bin/passwd -rws ...