首页 > 其他分享 >csp-s 模拟 8

csp-s 模拟 8

时间:2024-10-08 19:35:43浏览次数:8  
标签:考虑 正整数 S2 复杂度 大于 S1 csp 模拟

csp-s模拟8

T1 score and rank

特殊性质,题意转换

妙妙题

对于 \(S\) 小于等于 \(0\) 的情况答案显然是所有大于等于 \(S\) 的个数。

现在讨论 \(S\) 大于 \(0\) 的情况。

先对序列做一个前缀和,题目要求即是让所有值减去前缀最小值小于 \(S\)
考虑有一段连续正整数的和大于 \(S\),则贪心的从大到小删除序列中的值,直到和小于 \(S\)。
考虑有两段连续正整数中间夹着一段负数并且两段正整数的和都大于 \(S\) 而且这三段的和都大于 \(S\),依旧是考虑贪心删除,但需要考虑顺序,先对两段正整数段内贪心,若此时整段的和依旧大于 \(S\) 再合并贪心。

发现这种做法是可扩展的,但是时间复杂太高了。

观察题目性质发现对于一段正数后连着一段负数,记这两段的和分别为 \(S1,S2\),且 \(S1+S2>0\),那么对于前缀和而言删去那段正数中的数最多能对其后的值减少 \(S1+S2\) 的贡献,即就是说当删除的和大于 \(S1+S2\) 时就对这个题而言没有贡献了。对于上面的做法启发我们维护这个正整数段的前 \(k\) 大,且这前 k 大的和恰好大于 \(S1+S2\)。对于前者很好用堆去维护,后者该怎么维护呢?考虑用正数去填充负数,意思是说对于正整数断后的负数每添加进来一个就用正整数段中最小的正数去填充它直到为正然后再入堆,显然最后的值一定依旧是最小的,堆中的和恰好为 \(S1+S2\),对于本题的答案并不关心值而是关心个数,所以这样做是对的。如果堆中值的和不足以填充这个负数,则直接清空堆等同于连续段的左端点不可能在其左边。

每个数只会进出堆一次,所以时间复杂度为 \(O(nlogn)\)。

T2 HZOI大作战

签到题

由于数据较大,有点卡常卡空间。

离线下来对树上的点和询问向祖父中第一个大于自己的点连边,可以考虑倍增 \(max\) ,然后根据 \(dep\) 直接倍增跳就可以了。

时间复杂度 \(O(nlogn)\)

T3 Delov的旅行

二分,DP优化

题目的一些限制使得每个点只能进出子树各一次且最后回到根。

答案显然具有单调性,二分答案。

考虑怎么检查二分值是否合法,首先有个 naive 想法,设计状态 \(f_{i,x,y}\) 表示点 \(i\) 中最早遍历到的叶子节点到 \(i\) 的距离为 \(x\),最晚遍历到的叶子节点到 \(i\) 的距离为 \(y\) 是否合法,转移考虑背包即可,但是值域过大复杂度直接就炸了。但是发现每个叶子到个点的距离是固定的,所以会产生很多冗余的状态,那么就可以将所有的状态放到 \(vector\) 中就行了,但是此时依旧有冗余状态即对于 \(x_i≤x_j,y_i≤y_j\) 对于状态 \(j\) 而言显然是不如 \(i\),所以只需要维护一个 \(x\) 单调递增 \(y\) 严格单调递减的状态即可,排序去重,上双指针即可。注意左右儿子的顺序未定,且儿子本身也是可以翻转的,所以可以将状态两维 \(swap\) 一下再放入。

分析时间复杂度,每个点的状态数为它一个儿子的二倍,即每层有 \(O(n)\) 个状态,有 \(O(logn)\) 层,所以总时间复杂度为 \(O(nlognlogV)\)。

T4 gtm和joke的星球

斯坦纳树

模板题

首先答案的形态一定构成一颗树,因为若存在环,则可以删去一条环上的边使答案减少。

因为关键点的个数很少( \(k≤10\) ),所以可以考虑状压 + 树形 \(DP\) 去解决。设计状态 \(f_{i,s}\) 表示当以 i 这个点为根,且子树内具有的关键点包含 s 这个集合的最小答案,那么转移可以考虑集合合并以及根的转移。

集合合并 \(f_{i,s}=\min\{f_{i,s1}+f_{i,s2}\}(s1∪s2=s)\)

根的转移 \(f_{i,s}=\min\{w_{i,j}+f_{j,s}\}\)

对于第一种直接枚举子集转移就行了,第二种可以考虑在第一种整体转移完后(即这个集合对应的所有根都转移完后),进行最短路松弛即可。

分析时间复杂度,对于第一种转移,由于是枚举子集所以时间复杂度为子集的个数为 \(O(3^k)\)。对于第二种转移,每种集合都会进行一次最短路进行松弛,若使用 Dijkstra 则为 \(O(2^k(n+m)logm)\)。总时间复杂度为 \(O(3^k+2^k(n+m)logm)\)。

p

标签:考虑,正整数,S2,复杂度,大于,S1,csp,模拟
From: https://www.cnblogs.com/07Qyun/p/18450686

相关文章

  • XYD1005CSPS
    T1传送门[最短路,二分答案]Description无向连通图,求出一个最小的\(x\),使得每两点之间存在一条路径可以划分成不超过\(k\)段路径,且每段路径长度不超过\(x\),只能从节点处切割,不能从边中间划分。\(n\le100\),无重边自环。Solution\(n\)非常小,又要考虑每两个点,自然想到全......
  • 3.搜索、模拟
    搜索、模拟\(A\)luoguP1120小木棍\(B\)luoguP2540[NOIP2015提高组]斗地主加强版\(C\)CF58EExpression\(D\)CF293BDistinctPaths\(E\)[ABC352F]EstimateOrder\(F\)[ABC336F]RotationPuzzle\(G\)CF525EAnyaandCubes\(H\)luoguP9234买瓜\(I\)......
  • csp-s模拟10
    csp-s模拟10\(T1\)T3673.欧几里得的噩梦\(0pts\)部分分\(0\%\):状压加枚举子集。\(20\%\):线性基暴力做。正解\(T2\)T3672.清扫\(6pts\)原题:[AGC010C]Cleaning钦定根节点\(rt\)的度数\(\ge2\),所以需要特判\(n=2\)的情况。部分分未知\(pt......
  • csp-s模拟10
    rank31,垫底了,T10pts,T218pts,T30pts,T450pts状态有点不好,策略有问题,T4是可以切的,但是不知道为什么弃了。T1不会线性基寄。T3奇怪结论题,T2结论题。在猜结论上还是不行。T1欧几里得的噩梦用到了线性基线性无关的性质,将两个数连边,把环去掉,并查集判断即可。统计答案用快速......
  • Linux csplit命令
    csplit命令在Linux中用于将文件分割成多个部分,基于指定的模式或固定数量的行。与split命令不同,csplit允许更复杂的分割条件,例如基于正则表达式匹配或特定字符的出现次数。基本语法csplit[选项]文件名模式文件名:要分割的文件。模式:分割文件的依据,可以是正则表达式或数字。......
  • Day1 备战CCF-CSP练习
    Day1201403-1问题描述有$N$个非零且各不相同的整数。请你编一个程序求出它们中有多少对相反数($a$和$-a$为一对相反数)。输入格式第一行包含一个正整数$N$。$(1≤N≤500)$。第二行为$N$个用单个空格隔开的非零整数,每个数的绝对值不超过$1000$,保证这些整数各......
  • 『模拟赛』CSP-S模拟10
    Rank没学线性基输麻了,A.欧几里得的噩梦线性基,输麻了。B.清扫思维题,差点签了。(感觉其实不是很难啊,没有紫的水平)一个叶子结点和另一个叶子结点的最短路径一定经过它的父节点。根据这一性质可以让整棵树的合法性拆分成每个节点的合法性。考虑如何判断每个节点的合法性。......
  • [43] (CSP 集训) CSP-S 模拟 10
    B.清扫考虑从叶子节点往上推首先可以发现的几个性质子树内需要消除的数,要么通过子树根节点“发送”到上面(只经过子树内一个叶节点),要么通过自己的叶节点解决对于子树内既不是根也不是叶节点的节点,节点上的值只能由这一支路的叶节点消除,所以如果他节点上的值和下面节点“发......
  • 24南邮科协电子部笔试题 模拟基础
    第一题仅用KVL做题步骤:1.规定正方向。不妨规定顺时针为正方向。规定方向的主要目的是确定各个元器件的电压是降压还是升压。2.假设各个未知元器件的电压值和正负方向。如图3.数清回路数量,以回路为单位列KVL方程以回路1列KVL方程,升压为负,降压为正,代数和为0。不妨按照......
  • NZOJ 模拟赛5
    T1逃离遗迹根据外星人的回信,在遗迹中有分布着三样道具。当三样道具都拿走后,遗迹就很快自动毁灭,所以必须要在最短时间内离开。遗迹可以看作是由N个房间(编号1..N)和N-1条长度不等通道所组成,并且任意两个房间之间有且只有一条路可以相互到达。现在我们的队员已经在编号为A,B,C的......