https://www.iai.sh.cn/contest 2022.04 银组,理论上 \(100+100+30+100\)。

T1 上锁的抽屉

题目描述

有一个抽屉柜里竖排了 \(n\) 只抽屉。每个抽屉有一把锁。若要把一只抽屉『锁死』,就必须锁上它自己,而且要把它的上一层抽屉也锁上。请问有多少种上锁的方法,可以恰好『锁死』 \(m\) 只抽屉?

由于答案可能很大,输出方案数模 \(10^9+7\) 的余数。

大体思路

计数类问题显然想到动态规划。

一般地,设 \(f[i,j]\) 表示前 \(i\) 个抽屉『锁死』\(j\) 个的方案数。这样,我们只需要对第 \(i\) 个抽屉上锁是否影响『锁死』的个数即可。

此时我们发现,这还取决于第 \(i-1\) 个抽屉是否上锁。因此,我们规定 \(f[i,j,0]\) 表示前 \(i\) 个抽屉『锁死』\(j\) 个,且第 \(i\) 个抽屉不上锁的方案数,\(f[i,j,1]\) 表示前 \(i\) 个抽屉『锁死』\(j\) 个,且第 \(i\) 个抽屉上锁的方案数。

当第 \(i\) 个抽屉上锁时,我们可以借助第 \(i-1\) 个抽屉上锁,则之前『锁死』的个数为 \(j-1\) 个;也可能第 \(i-1\) 个抽屉不上锁,则前 \(i-1\) 个需要『锁死』\(j\) 个。第 \(i\) 个抽屉不上锁时,必然完全依靠前 \(i-1\) 个抽屉『锁死』\(j\) 个,由此可得状态转移方程:

\[f[i,j,0]=f[i-1,j,1]+f[i-1,j,0]\\
f[i,j,1]=f[i-1,j-1,1]+f[i-1,j,0]\]

其边界条件为 \(f[1,1,1]=f[1,0,0]=1\),答案为 \(f[n,m,1]+f[n,m,0]\),注意取模。

这样,时空复杂度为 \(O(nm)\)。注意到 \(i\) 的决策只与 \(i-1\) 相关,可以使用滚动数组使得空间复杂度降至 \(O(m)\)。

ll n, m, f[2][maxn][2];
/*
f[i, j, 0] 表示前i个抽屉锁死j个,i不锁死
f[i, j, 1] ......................i锁死 f[1,0,0]=f[1,1,1]=1
f[i,j,0]=f[i-1,j,1]+f[i-1,j,0]
f[i,j,1]=f[i-1,j-1,1]+f[i-1,j,0]
(j > 0)
*/
int main () {
read(n); read(m);
f[1][0][0] = f[1][1][1] = 1;
rep(i, 2, n) {
rep(j, 0, i) {
f[i&1][j][0] = (f[(i-1)&1][j][1] + f[(i-1)&1][j][0]) % mod;
f[i&1][j][1] = f[(i-1)&1][j][0];
if(j > 0) (f[i&1][j][1] += f[(i-1)&1][j - 1][1]) %= mod;
}
}
writeln((f[n&1][m][0] + f[n&1][m][1]) % mod);
return 0;
}

T2 匹配括号(二)

题目描述

给定一个仅由 ()[] 构成的字符串,若它不是匹配的,请求出最少删去多少括号可以使它变成匹配的。匹配定义如下:

  • 空字符串是匹配的;
  • 如果字符串 \(s\) 是匹配的,那么 \((s)\) 与 \([s]\) 也是匹配的;
  • 如果字符串 \(s\) 与 \(t\) 都是匹配的,那么 \(st\) 也是匹配的。

大体思路

原题链接 https://loj.ac/p/10150

由于匹配的括号串每一个子串都匹配,考虑区间 DP。设 \(f[i,j]\) 表示区间 \([i,j]\) 最少删去的括号个数。边界 \(f[i,i]=1\)。

括号匹配是经典的讨论边界的区间 DP。如果 \(s_i,s_j\) 互相匹配,则有初始值 \(f[i,j]=f[i+1,j-1]\),否则初始为 \(\infty\)。然后枚举分割点 \(k\in [i,j)\),\(f[i,j]=\min\{f[i,k]+f[k+1,j]\}\)。最终答案即为 \(f[1,n]\),时间复杂度 \(O(n^3)\)。

T3 末日生存

题目描述

小爱正在参加一个末日生存比赛,每过一天要消耗一个单位的物资,最后一天到来之前,如果她没有物资,就输了。游戏一共要持续 \(d\) 天,出发前,小爱有 \(c\) 个单位的物资。

游戏过程中有 \(n\) 次补给机会,第 \(i\) 次补给机会在第 \(x_i\) 天 ,当天可以补给 \(a_i\) 个单位的物资。

请设计一个方案,使得小爱能够坚持到最后一天,且补给的次数最小。如果无论如何都到不了终点,输出 Impossible

大体思路

考场上没有思路,感觉和之前某个旅行商问题很像,但显然不一样。于是直接使用 \(dfs\),记 \(dfs(N,C)\) 表示到达第 \(N\) 个补给站时还有 \(C\) 的物资的次数,然后对第 \(N\) 个补给站是否补充物资进行讨论,时间复杂度 \(O(2^n)\),期望得分 \(30\)。

T4 狼人游戏

题目描述

有 \(n\) 个人在一起玩狼人游戏,游戏中有一些玩家的身份是狼人,剩下玩家的身份是平民。狼人知道彼此之间的身份,而平民对其他人的身份信息一无所知。

天亮时,每名玩家要指证另一名玩家是狼人。狼人一定会做伪证,指证某个平民为狼人,而平民可能指证某个狼人,也可能指证另一个平民。

给定每名玩家的指证对象,请分析场面上最多可能有多少名狼人?注意游戏规定至少需要有一名平民。

大体思路

原题 [COCI2014-2015#1] MAFIJA,正好做到过。

将指认关系进行连边,\(n\) 个节点 \(n\) 条边形成基环树(基环森林)。

用并查集维护环,对于每一个环,将其断开后变为一棵树,然后将这两个节点 \(u,v\) 分别作为根跑树形 DP 即可,答案累加 \(\max(f[u,0],f[v,0])\)。动态规划的复杂度为 \(O(n)\),总复杂度为 \(O(n\log n)\),瓶颈在于并查集。

此题由于所有点权均为 \(1\),还有 \(O(n)\) 的贪心做法,但由于推广性不强,在此不介绍。

/*
f[u][0]+=max(f[v][0], f[v][1])
f[u][1] = 1 + f[v][0]
max f[u][0], f[v][0]
*/
int n, id[maxn], f[maxn][2], ans;
int tot = 1, hd[maxn], ver[maxn * 2], nxt[maxn * 2];
inline void add(int u, int v) {
ver[++tot] = v; nxt[tot] = hd[u]; hd[u] = tot;
ver[++tot] = u; nxt[tot] = hd[v]; hd[v] = tot;
}
PII p[maxn]; // cir
bool vis[maxn * 2];
inline void dfs(int u, int fa) {
f[u][0] = 0, f[u][1] = 1;
for(int i = hd[u]; i; i = nxt[i]) {
int v = ver[i];
if(vis[i] || vis[i ^ 1] || v == fa) continue;
dfs(v, u);
f[u][0] += max(f[v][0], f[v][1]);
f[u][1] += f[v][0];
}
}
int fa[maxn];
inline int find(int k) {
return (k == fa[k] ? k : fa[k] = find(fa[k]));
}
int main () {
read(n);
rep(i, 1, n) fa[i] = i;
rep(u, 1, n) {
int v; read(v);
add(u, v);
int f1 = find(u), f2 = find(v);
if(f1 != f2) fa[f1] = f2;
else {
id[++id[0]] = tot;
p[id[0]] = {u, v};
}
}
rep(i, 1, id[0]) {
int u = p[i].first, v = p[i].second;
vis[id[i]] = vis[id[i] ^ 1] = 1;
dfs(u, 0);
int tmp = f[u][0];
dfs(v, 0);
ans += max(tmp, f[v][0]);
vis[id[i]] = vis[id[i] ^ 1] = 0;
}
writeln(ans);
return 0;
}

YACS-2022.4-银组的更多相关文章

  1. usaco 2010年3月银组题解

    usaco银组解题报告 一.石子游戏如果把‘O’当作0,‘X’当做1,则N个洞的每一种状态都可以看做是一个N位二进制数.于是,这个问题就变成了求环绕的N位格雷码.幸运的是,这个结构很容易就能够用一个简 ...

  2. BZOJ USACO 银组 水题集锦

    最近刷银组刷得好欢快,好像都是水题,在这里吧他们都记录一下吧(都是水题大家一定是道道都虐的把= =)几道比较神奇的题到时再列出来单独讲一下吧= =(其实我会说是BZOJ蹦了无聊再来写的么 = =) [ ...

  3. USACO 2014 FEB 银组

    1.自动打字{Silver题1} [问题描述] 贝西新买了手机,打字不方便,请设计一款应用,帮助她快速发消息. 字典里有W(W<=30000)个小写字母构成的单词,所有单词的字符总数量不超过1, ...

  4. 【Usaco2014Open银组】双导航(gpsdual)

    题目 [题目描述] FJ 最近网购了一台小车.但是由于他的草率,在选择加装物品时偶然地点击了两次"Submit" ,结果最后他的小车装了两台GPS 导航系统!更糟的是,这两个系统对 ...

  5. USACO[19-20]Dec银组题解

    1,MooBuzz 这题其实是道数学题. 我们先找找符合要求的数:1,2,4,7,8,11,13,14…… 我们发现再往后找都是这8个数中的一个加15k如:16……19……29…… 找规律发现k=n/ ...

  6. 2022.2.26A组总结&反思

    今天的发挥比较奇妙.. T1:一眼dp+高斯消元,但是感觉细节比较多,然后先去做了T2,写完后回来推了一下就做出来了.比较裸,但是细节确实多,但是很可惜的一点是最后提交的代码没有判不合法,到手的100 ...

  7. noip2015 提高组 解题报告

    完美退役...说好的不卡常呢QAQ day1: T1:模拟题?..考察选手将题目描述翻译成代码的能力233 //其实真相是考验rp..论代码雷同的危害233 T2:简单图论,每个点出度为1所以是基环内 ...

  8. 要立刷金组flag了T_T

    刷了那么多银组,发现自己好多不会啊... 果然太弱 在这感谢hzwer神犇的blog.. 大部分题解都从黄学长这里来orz. orz.... 果然我太水

  9. bzoj1720: [Usaco2006 Jan]Corral the Cows 奶牛围栏

    金组题什么的都要绕个弯才能AC..不想银组套模板= = 题目大意:给n个点,求最小边长使得此正方形内的点数不少于c个 首先一看题就知道要二分边长len 本来打算用二维前缀和来判断,显然时间会爆,而且坐 ...

随机推荐

  1. .NET6: 开发基于WPF的摩登三维工业软件 (8) - MVVM

    基于WPF开发界面的一个很大优势是可以方便地基于MVVM设计模式开发应用.本文从应用的角度基于MVVM实现参数化管材的创建界面. 1 MVVM MVVM是Model-View-ViewModel的简写 ...

  2. ubuntu 学习中的坑-2021-11-22

    安装ssh-server服务 查看是否安装ssh服务 #dpkg -l | grep ssh 安装ssh-server服务 #sudo apt-get install openssh-server 然 ...

  3. 04 变量 变量作用域 常量final 变量的命名规范

    变量 变量是什么:就是可以变化的量! Java是一种强类型语言,每个变量都必须声明其类型. Java变量是程序中最基本的存储单元,其要素包括变量名,变量类型和作用域. 注意事项: 每个变量都有类型,类 ...

  4. 腾讯2021LIGHT公益创新挑战赛赛题分析

    前些日子老师让我们报名了LIGHT挑战赛,之后又简单的进行了分析,今天我总结复盘一下,一是为了捋一下自己选题的思路,二是以后遇见类似的项目,更容易找到方向或者触类旁通. 赛题介绍 赛题一:安全教育/保 ...

  5. 报错 ———— Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 2; columnNumber: 6; 不允许有匹配 "[xX][mM][lL]" 的处理指令目标。

    报错 <?xml version="1.0" encoding="UTF-8"?>  必须是XML文件的第一个元素且前面不能空格. ### Erro ...

  6. 八、Java面向对象编程

    Java面向对象 初识面向对象 面向过程 & 面向对象 面向过程思想 步骤清晰简单,第一步做什么,第二部做什么... 面对过程适合处理一些较为简单的问题 面向对象思想 物以类聚,分类的思维模式 ...

  7. 内置方法 __str__ __repr__

    内置方法(双下方法,魔术方法) 在不需要程序员定义,本身就存在的类中的方法就是内置方法 内置方法:  __名字__ __init__   不需要我们主动调用,而是在实例化的时候内部自动调用的,存在一种 ...

  8. AFO以后的机房游记

    2019.8.6~8.8 周老师让我讲插头DP,理所当然地到机房备课(tuifei) dl24来了足足19个人.只可惜lsy没来,我们的phy,ljx去了首师附.看不到神仙打架了[哭] 插头DP这玩意 ...

  9. 使用postman进行post请求传递中文导致后台接收乱码的问题

    1.个人猜测估计是如果header里不指明编码的话,经过tomcat服务器时会导致转换乱码信息,这样就算你在filter里配置了EncodingFilter相关的过滤器也无济于事.. 解决方法就是在h ...

  10. React优点?

    声明式, 组件化, 一次学习, 随处编写. 灵活, 丰富, 轻巧, 高效