摘要: 洛谷题目链接 At题目链接 这题一看就很欧拉路径,但是怎么做呢? 如果只有关键边,那么连通图首先会变成一堆连通块,这时只需要分别对每个连通块进行欧拉路径判断,但是对于不属于欧拉路径的连通块,很难对加上非关键边的情况进行扩展。 如果只有非关键边,那么连通图还是变成一堆连通块,但是这些连通块全部都是合法 阅读全文
posted @ 2023-11-10 12:05 2017BeiJiang 阅读(9) 评论(0) 推荐(0) 编辑
摘要: 题目链接 既然只有两种东西,我们不妨分开考虑,这里也借鉴了很多二分图题目的切入点。 假设苹果和桔子下标分别如下图所示: 苹果:1 3 6 7 9 10 桔子:2 4 5 8 那么第一次取,应该是这样取: 1 2 3 4 6 8 9 也就是先取开头比较小的,然后轮流取,注意一定保证递增,也就是对于苹果 阅读全文
posted @ 2023-11-09 20:20 2017BeiJiang 阅读(69) 评论(0) 推荐(0) 编辑
摘要: [USACO23OPEN] Pareidolia S 对于这种题,两种思路,一种是直接 \(dp\),一种是考虑每个 bessie 产生的贡献。 显然直接考虑 bessie 产生的贡献难以解决 bbessie 的情况,所以考虑 \(dp\)。 设 \(f_{i}\) 表示以 \(i\) 开头的字符串 阅读全文
posted @ 2023-11-04 10:45 2017BeiJiang 阅读(14) 评论(0) 推荐(0) 编辑
摘要: [CSP-S2020] 儒略日 今儿终于做掉困扰多年的题目了,其实想好细节也不难。 容易发现儒略历和格里高利历的润年判断方式不一样,并且中间有消失的十天,计算起来相当不方便。所以我们可以首先计算出 \(-4713.1.1\) ~ \(1582.10.4\) 会经过多少天,可以通过一天一天暴力跳的方法 阅读全文
posted @ 2023-10-30 21:45 2017BeiJiang 阅读(31) 评论(0) 推荐(0) 编辑
摘要: 题目链接 \(\rm O(n^3)\) 枚举 \(i,j,k\) 的算法是显然的。 考虑优化掉一个 \(n\),如果枚举 \(i,j\),那么显然需要找出有多少个 \(k\) 同时满足 \(a_{i,k}=a_{j,k}=1\),我们可以将 \(a_i\) 和 \(a_j\) 看作两个二进制数,那么 阅读全文
posted @ 2023-10-14 22:38 2017BeiJiang 阅读(6) 评论(0) 推荐(0) 编辑
摘要: 题目链接 相当牛逼。 这种找数量的题型,确定树形 \(dp\) 没跑了。 首先思考常规树形 \(dp\),不难想到设 \(f_{u,a,b}\) 表示以 \(u\) 为根节点的子树内(包括点 \(u\)),最大值是 \(a\),最小值是 \(b\) 的连通子图数量,转移很容易,但是这样时间空间复杂度 阅读全文
posted @ 2023-10-12 17:02 2017BeiJiang 阅读(2) 评论(0) 推荐(0) 编辑
摘要: 有一种和题解区完全不同的做法。 首先将所有任务按照时间从小到大排序,接着用 \(f_i\) 表示处理前 \(i\) 个任务所能得到的最大空闲时间。 回顾一下需要满足的条件:再某个有任务的时刻,如果尼克是空闲的,就必须从中选择一个任务做。那么我们对于第 \(i\) 个任务,枚举上一个做的任务 \(j\ 阅读全文
posted @ 2023-10-08 22:54 2017BeiJiang 阅读(2) 评论(0) 推荐(0) 编辑
摘要: 题目链接 对于括号问题,考虑区间 \(dp\)。这道题的括号序列是固定的,所以直接找出每个括号对应的括号在进行转化即可。 设 \(f_{l,r,0/1/2,0/1/2}\) 表示 \(l\sim r\),左括号不染色/染红色/染蓝色,右括号不染色/染红色/染蓝色的方案数。 若 \(l,r\) 是一对 阅读全文
posted @ 2023-10-03 22:47 2017BeiJiang 阅读(18) 评论(0) 推荐(0) 编辑
摘要: 题目链接 对于括号题,基本是栈匹配没有匹配的左括号和区间 \(dp\) 两个方向。这道题括号序列并不确定,只能用区间 \(dp\) 搞。 如果直接设 \(f_{l,r}\) 表示 \(l\sim r\) 的合法括号序列,那么由区间 \(dp\) 的套路可知,需要枚举中间点进行合并,那么 \(()() 阅读全文
posted @ 2023-10-03 14:37 2017BeiJiang 阅读(55) 评论(0) 推荐(0) 编辑
摘要: 题目链接 本题解讲解环图的做法。 要将一个 \(1\sim n\) 的排列通过交换变成 \(1\sim n\),可以先将 \(i\) 向 \(a_i\) 连边,那么最终一定会练成若干个环(每个点只有一个出度,也只有一个入度)。 假设交换在同一个环中的节点,一个环显然会变成两个环,也就是说,交换一次最 阅读全文
posted @ 2023-10-03 12:09 2017BeiJiang 阅读(13) 评论(0) 推荐(0) 编辑
摘要: 题目链接 先将所有作业按位置排序。 直接贪心显然是不行的,因为我们没有办法确定对于一个时间较久的作业,是在原地等待,还是在未来的某个节点返回,并且无法确定是那个节点,所以只能考虑 \(dp\)。 对于此类可以倒来倒去的问题,通常考虑区间 \(dp\),若设 \(f_{i,j}\) 表示完成区间 \( 阅读全文
posted @ 2023-10-02 12:05 2017BeiJiang 阅读(4) 评论(0) 推荐(0) 编辑
摘要: 题目链接 首先可以想到设状态 \(k_1,k_2\) 表示小 \(a\) 和小 \(uim\) 分别表示他们目前取得的得分,那么最终的答案便是 \(k_1=k_2\) 的时候。 但是这样设置状态的复杂度无疑是高的。并且十分浪费,所以考虑设 \(z\) 表示 \(k_1-k_2\) 的值。那么 \(z 阅读全文
posted @ 2023-10-02 10:06 2017BeiJiang 阅读(2) 评论(0) 推荐(0) 编辑
摘要: 矩阵是一种数学概念,在 \(OI\) 中有着重要应用。 一个矩阵有行,列,以及里面的数字。如图便是一个 \(2\) 行 \(3\) 列的矩阵: \[ \begin{bmatrix} 1 &2 &3\\ 4 &5 &6\\ \end{bmatrix} \] 矩阵数乘 \(\lambda A\) 就是将 阅读全文
posted @ 2023-09-29 10:42 2017BeiJiang 阅读(16) 评论(0) 推荐(0) 编辑
摘要: 题目链接 看到这道题按照套路首先想到二分答案(即二分 \(q\) 位置上的数,记作 \(mid\))。 再按照套路将大于 \(mid\) 的数字设为 \(1\),将等于 \(mid\) 的数设为 \(2\),小于 \(mid\) 的数字设为 \(0\)。 那么对于区间 \([l,r,0]\) 操作, 阅读全文
posted @ 2023-09-28 12:03 2017BeiJiang 阅读(2) 评论(0) 推荐(0) 编辑
摘要: 题目链接 要想使得数字 \(x\) 是中位数,就必须选出 \(k\) 个小于 \(x\) 的数和 \(k\) 个大于 \(x\) 的数。 我们考虑对数字附上特殊值,小于 \(x\) 的数赋值为 \(-1\),大于 \(x\) 的数赋值为 \(1\),\(x\) 则赋值为 \(0\),那么若一段包含 阅读全文
posted @ 2023-09-09 18:32 2017BeiJiang 阅读(4) 评论(0) 推荐(0) 编辑