把博客园图标替换成自己的图标
把博客园图标替换成自己的图标end
上一页 1 ··· 5 6 7 8 9 10 11 下一页
摘要: 线性基求第 \(k\) 大,先处理 \(p_i\),表示某一位上为 \(1\),其他数这一位是 \(0\) 的数,然后我们就会考虑选与不选,由于只有一个数这一位上有 \(1\),所以就转换成了二进制选取。 什么时候线段树合并要新建节点?(更为厉害【湖南集训】)很显然,我不新建节点会导致一些线段树上面 阅读全文
posted @ 2025-08-02 15:02 high_skyy 阅读(11) 评论(0) 推荐(0)
摘要: ## 概述 给你一个长度为 $n$ 的排列 $p$,定义集合: $$ S_i=\{x\mid x\geq i\wedge \max_{k\in[i,x-1]}p_k 阅读全文
posted @ 2025-08-01 11:08 high_skyy 阅读(14) 评论(0) 推荐(0)
摘要: ## 题目概述 给你一个排列 $p$,共有 $n$ 个元素,你可以选择两个数 $i,j$,然后将 $p_i$ 移动到位置 $j$,这个过程需要花费 $i+j$ 的代价,问你通过这些操作过后所能使 $p$ 变为降序的最小代价。 ## 思路 变成降序似乎不是我们所擅长的,我们先转化为变成升序,这个是容易的只需要令 $p_i=n-p_i+1$ 即可。 我们先考虑暴力的做法,总结出来一些性质: - 每个数显然只能移动一次,如果移动了两次还不如一步到位。 - 按照从大到小的顺序移动这些数比按照其他顺序移动更好。 因此我们可以得到 $\mathcal{O}(n2^n)$ 的暴力。 阅读全文
posted @ 2025-07-30 12:27 high_skyy 阅读(44) 评论(0) 推荐(0)
摘要: ## 基本算法 ### 求无序数组(不可排序)的前驱和后继(比当前值小) 考虑离线使用 `stack` 来进行维护。 顺序遍历的时候,求的是 $i$ 之前能否到达 $i$,不能就标记数组 `right[sta.top()] = i`,容易证明只是所能到达的最远。 倒序遍历同理。 时间复杂度 $\mathcal{O}(n)$,是一个离线算法(预处理)。 阅读全文
posted @ 2025-04-22 20:26 high_skyy 阅读(10) 评论(0) 推荐(0)
摘要: # CF140E New Year Garland 题目分析 挺不错的动态规划题目。 ## 思路 一看到题目便可以知道每一层和层与层之间是要分开来算的(这种类似的动态规划还有很多)。 我们先看看层与层之间的。 ### 层与层 题目要求:**相邻的两层的小球颜色集合不相同**。 那么区分相邻两层小球颜色集合不同可以通过**数量不同来区分**,然后再进行讨论即可。 根据上述,显然地,设 $f_{i,j}$ 表示已经完成前 $i$ 层,到了第 $i$ 层小球颜色集合的数量为 $j$ 的总方案。 我们先抛开重不重复不谈,那么它的总方案肯定是从前面的那一层转移过来,即 $f_{i-1,k}$,其中 $k\in [1,l_{i-1}]$。 那么是不是就是 $$ f_{i,j}=\sum_{k=1}^{l_{i-1}}f_{i-1,k} $$ 呢?显然不是,这里的 $j$ 是数量,并不是选了什么,因此还要有 $C_m^j$ 来确定选 $j$ 种颜色球的方案(这是对于当前 $i$ 的)。 阅读全文
posted @ 2025-03-11 19:17 high_skyy 阅读(19) 评论(0) 推荐(0)
摘要: 1.浅谈一些数论函数 阅读全文
posted @ 2025-03-02 22:31 high_skyy 阅读(53) 评论(0) 推荐(0)
摘要: 给一个 $1$ 到 $n$ 的排列 $a$,并且给出点权 $x_i$,并定义: $$ LCA\{b\}=lca(lca(\dots(b_1,b_2),\dots),b_m) $$ 其中 $lca(x,y)$ 表示 $x$ 和 $y$ 的最近公共祖先。 并且给出一颗树。 求: $$ ans=\sum_{i=1}^n\sum_{j=i+1}^nx_{LCA_{i\in[i,j]}\{a_i\}} $$ 像这种比较经典的双 sigma 题目,最最最最暴力的解法是 $\mathcal{O}(n^3)$(先不考虑这里求 $LCA$ 的 $\log$)。 于是就很简单地拿到了此题的 $40$ 分。 那么怎么优化到 $\mathcal{O}(n\log n)$ 呢? 我一般的思路是直接上线段树。 我们这颗线段树(显然维护的是 $dfs$ 序区间)维护两个值,一个是 $cnt$ 代表这段区间内有点作为 $lca$ 的总方案,$sum$ 就是加和实际的数量 $\times x_{lca}$,注意到这里只有在有可能作为 $lca$ 的点上相乘,`pushup` 的时候都是加和(这里的思路比较巧妙)。 阅读全文
posted @ 2025-02-11 11:18 high_skyy 阅读(13) 评论(0) 推荐(0)
摘要: ## 评价 一道非常好的思维题目!!! ## 分析 注意到:从三个数选一个中位数。 似乎没有什么好的方法,但是每一层的迭代有一种相似方法。 我们假设一个答案。 将大于等于答案的标记为 $1$,其他的为 $0$。 三——一个非常重要的数,我们要考虑以下: ``` 全是0:000 -> 0 一个1:001 -> 0 两个1:101 -> 1 三个1:111 -> 1 ``` 我们发现得到的答案取决于数量($0$ 多还是 $1$ 多)。 那我们怎么确定他能一直走到尾呢? 注意到: ``` ??? -----> 00? x00zy x00zy ``` 也就是说,两个连续的在一起,能够使得上面也一样(但是要看边界)。 注意到要是中间有连续的(即最靠近中间的一段 $0$ 或者 $1$)说明顶尖就是大于等于数字。 我们发现这样具有单调性,于是乎可以考虑二分答案解决。 然后我们就很好的解决了该问题。 总时间复杂度 $\mathcal{O}(n\log n).$ 阅读全文
posted @ 2025-02-09 12:19 high_skyy 阅读(26) 评论(0) 推荐(0)
摘要: [题目链接](https://www.luogu.com.cn/problem/P6815) ## 分析题目性质 本质上是求三个点组成的环的点权最大值的和。 ## 思路 考虑枚举第一个点 $i$,然后枚举与其相邻的第二个点 $j$,用 $set$ 存储 $i,j$ 相连的点,最后判断得出答案。 我们发现满足答案的满足 $i 阅读全文
posted @ 2024-12-05 19:43 high_skyy 阅读(30) 评论(0) 推荐(0)
摘要: # 就 NOIP2024 中出现的问题进行深入探讨 估分:$100+0+0+0=100.$ 好吧,为了一道蓝题我花了 $2\text{ h }45\min.$ 其实原因很简单——因为代码实现细节很多导致 $20$ 多分钟想出来的东西隔了 $1h$ 才去实现,并且代码能力不够,调了 $1h$ 才过大样例。 $T_2$ 想了差不多 $30$ 分钟得出了一个很显然的 $\mathcal{O}(n)$ 的 $dp$,但是到了最后没有调出来。考后才发现一道绿题卡我这么久!——原因是没有想到**正难则反**。 所以原本实力:$100+100+0+0=200.$ 总结原因: - 代码能力不够,在这里浪费的时间超过 $1h.$ - 不坚信自己的能力,比如说 $T_1$ 想到正解但是因为细节多没有打。 - 数学方面没有形成思维,比如正难则反。 - 自己不够熟练。 阅读全文
posted @ 2024-12-03 12:40 high_skyy 阅读(120) 评论(0) 推荐(0)
上一页 1 ··· 5 6 7 8 9 10 11 下一页
浏览器标题切换
浏览器标题切换end