\(\text{High Card Low Card}\)

USACO2015DEC Platinum T2

贝西和艾尔西在玩游戏。有 \(2n\) 张牌,牌上的数字是 \(1\) 到 \(2n\) ,贝西 \(n\) 张,艾尔西 \(n\) 张。

贝西事先知道艾尔西先后出的 \(n\) 张牌。

她们进行 \(n\) 轮出牌,轮流各出一张牌。一开始,谁的数字大谁赢。

贝西有一个特殊权利,她可以在任意时刻把规则从谁大谁赢改成谁小谁赢,问贝西最多能赢多少轮。

\(2\le n\le 50000\)

\(1.00s,\ 128\ MB\)

Solution

考虑贪心。

我们记 $pre[i]$ 表示 $1$ 到 $i$ 中最多能赢几局, $suf[i]$ 表示 $i$ 到 $n$ 中最多能赢几局。

答案 $ans = \min\limits_{i=0}^{n} (pre[i] + suf[i+1])$

如果前面和后面选的数重复了怎么办?不存在这种情况!

你如果两个地方用的同一张牌i,肯定有一张牌没被用,那么分情况讨论。

1.比这张牌大。 那么这张牌可以替换掉在规则1下的牌i

2.比这张牌小。 那么这张牌可以替换掉在规则2下的牌i

中间过程用两个 $set$ 维护一下即可

复杂度 $O(nlogn)$


\(\text{Cave Paintings}\)

USACO2020JAN Platinum T1

给你一张 \(n\times m\) 的图,每个格子要么是空的,要么是石头

你可以给空格子上水,但是上完后的图要真实的(符合水不会再向四周流动)。

问你所有合法的上色的方案数,答案对 \(10^9+7\) 取模。

\(1\le n,m\le 1000\)

\(2.00s,\ 256\ MB\)

Solution

从下往上考虑,显然一层可以分成若干段空格子,使得每一段都是连通的。

观察知这是一个树形结构,那么我们可以做类树形dp:

$dp_u = 1 + \Pi _{v\in son(u)} dp_v$

从下往上用并查集维护就行了。

复杂度 $O(nm)$


\(\text{Help Yourself}\)

USACO2020FEB Platinum T3

在一维数轴上有 \(n\) 条线段,第 \(i\) 条线段包含满足 \(l_i \le x \le r_i\) 的所有实数 \(x\) 。

定义一组线段的为所有被至少一条线段所包含的实数 \(x\) 的集合。

定义一组线段的复杂度为这些线段的并的连通区域数量的 \(K\) 次方。

计算所有 \(2^n\) 个子集的线段组复杂度之和,答案对 \(10^9+7\) 取模。

\(1\le n\le 10^5, 2\le K\le 10, l_i < r_i, 保证 \{ l_i, r_i\} = \{ 1, 2, ..., 2n-1,2n \}\ (1\le i\le n)\)

\(2.00s,\ 256\ MB\)

Solution

首先将这些线段按左端点先排好序。

考虑 $K=1$ 时如何做。这一档是 Gold T2 原题。

用 $dp[i]$ 表示前 $i$ 个线段的 $2^i$ 个子集的线段组复杂度之和。

那么第 $i$ 根线段不选: $dp[i-1]$ ;

第 $i$ 根线段选:$dp[i-1]+一些额外产生的贡献$

注意左端点已排好序,所以要想产生贡献,则之前的线段的右端点均小于该线段的左端点。

右端点我们可以利用前缀和提前预处理,于是这一部分的贡献就可以计算了。

接下来是正解时刻:

![QQ图片20200521214107.png](https://i.loli.net/2020/05/23/a7M5X1QcyDrRwJP.png)

USACO 刷题小记的更多相关文章

  1. USACO刷题之路

    重拾经典 本科生涯结束了,在大学做的ACM竞赛现在基本忘的差不多了.USACO作为一个经典的题库,本来是面向OI选手的,但是由于题目质量很高所以受到大家的好评,所以我这次就从它开始我的刷题之路吧. 由 ...

  2. USACO刷题之路,开始了

    几天前,重新开始刷题了. 重新刷题有几个原因: 1.曾经的OI经历,如今除了悟性高些.知识多些,大多已经遗忘.不希望真的让之前的OI水平就这么丢了. 2.越来越觉得,刷题真的是一件很开心的事情.大学中 ...

  3. USACO 刷题有感

    最近每天都尽量保持着每天一道USACO的题目,呵呵,一开始都是满简单的,一看题目基本上思路就哗啦啦地出来了,只不过代码实现有点麻烦,花了一些时间去调试,总体感觉还不错,但是越往后做,应该就很难保持一天 ...

  4. USACO 刷题记录bzoj

    bzoj 1606: [Usaco2008 Dec]Hay For Sale 购买干草——背包 #include<cstdio> #include<cstring> #incl ...

  5. Atcoder刷题小记

    1. 2019.4.27 agc016d 一道很坑的题. 首先判无解,求出异或值后排个序就可以. 然后直接让\(a_i\rightarrow b_i\)并查集维护,注意离散化和判重,答案加上联通块个数 ...

  6. USACO刷题索引

    序 在距离CSP2019还有41天的国庆备战中,考了一场画风非常奇特的六校联赛,然后被教练建议刷一下这个巩固代码实现能力,然后就来了||ヽ(* ̄▽ ̄*)ノミ|Ю. 这个网站还是挺好玩儿的吧,刚开始各种 ...

  7. LintCode刷题小记491

    题目: 判断一个正整数是不是回文数. 回文数的定义是,将这个数反转之后,得到的数仍然是同一个数. 样例: 11, 121, 1, 12321 这些是回文数. 23, 32, 1232 这些不是回文数. ...

  8. 【刷题记录】BZOJ-USACO

    接下来要滚去bzoj刷usaco的题目辣=v=在博客记录一下刷题情况,以及存一存代码咯.加油! 1.[bzoj1597][Usaco2008 Mar]土地购买 #include<cstdio&g ...

  9. USACO 好题汇总

    背景 这里主要是用来针对USACO上的题目的二次汇总,因为我在刷题的过程中,有的题目我是可以很快想到解决方案的,对于这种题目,就没有必要深究了.但是有一些题目对于我来说还是有一些挑战的,可能用朴素的算 ...

随机推荐

  1. 关于 video 播放的新探索

    前端同学要使用 HTML5 播放器视频,必然会使用 video 标签,不过大多数同学只是使用了较简单的功能,其实它本身拥有不凡之力有待我们发现. 首先,我们先来看下 video 最基础的用法: 使用 ...

  2. PAT B1042 字符统计

    请编写程序,找出一段给定文字中出现最频繁的那个英文字母. 输入格式: 输入在一行中给出一个长度不超过 1000 的字符串.字符串由 ASCII 码表中任意可见字符及空格组成,至少包含 1 个英文字母, ...

  3. 数据库number(4,3)表示什么

    1 你看 number(4,3)是表示 这个数 一共有4位是有效位,后面的3 表示有3个是小数也就是这个数 只能是1.234,这样格式的 最大只能是9.999,2 number(3,4) 表示这个数 ...

  4. jq移动端图片预览 (fly-zomm-img.js)

    效果图: ===>==> 里面还与很多属性设置: index  关闭按钮等等 代码: //html-----------------------<div class="he ...

  5. datasets数据读取器

    #切分数据集 img_dir = train_parameters['img_dir'] file_name = train_parameters['file_name'] df = pd.read_ ...

  6. Spring集成web环境(手动实现)

    1.创建UserDao接口及其实现类UserDaoImpl(接口代码省略) public class UserDaoImpl implements UserDao { @Override public ...

  7. DRF 过滤排序分页异常处理

    DRF 中如何使用过滤,排序,分页,以及报错了如何处理?10分钟get了~

  8. 用asmlib方式创建oracle集群ASM磁盘(oracleasm)

    创建asm磁盘的几种方式 创建asm方式很多主要有以下几种 1.Faking方式 2.裸设备方式 3.udev方式(它下面有两种方式) 3.1 uuid方式 3.2 raw方式(裸设备方式) 4.as ...

  9. MySQL 社区版

    MySQL 社区版 MySQL 社区版是全球广受欢迎的开源数据库的免费下载版本.它遵循 GPL 许可协议,由庞大.活跃的开源开发人员社区提供支持. MySQL 社区版包括: 可插拔的存储引擎架构 多种 ...

  10. node.js - http、模块化、npm

    今天是node学习的第二天,其实越往后面学越感觉有点熟悉的味道了,光针对于node来说哈,为什么呢,因为我之前学过一点云计算的东西,当时感觉没什么用搞了下服务器客户端这些,没想到这里还能用一用,至少看 ...