20210719 noip20
考场
后两题是原题,教练说不用写了(ycx 不讲武德)
T1 先手模了 \(n\le5\) 的情况,尝试找规律失败。那就只能 DP 了,最终没搞出来。
记忆化搜索打了 \(n\le20\) 的表,交了
res
30pts
少模了,爆了 20pts。。。
rk1 赵思远 100+81+45
rk4 ys 30+72+65
玩具
具体做法可以看hzoi巨佬的博客(虽然有锅)
这里补充一下细节和如何想到。(下文中高度 = 深度,按边数计)
显然题意为求 \(n\) 个点的树树高期望
一个 naive 的想法设状态为 \(f[i,j]\) 表示 \(i\) 个点的树树高为 \(j\) 的概率,但直接转移需要知道每个深度度有多少个点,显然不行。那么考虑有若干个树加一个根拼起来,设 \(g[i,j]\) 为 \(i\) 个点的森林深度为 \(j\) 的概率,那么 \(f[i,j]=g[i-1,j-1]\),问题转化为求 \(g\)。
考虑枚举第一棵树中有多少点,那么可以由第一棵树+其他点的森林转移而来,但这样还要枚举深度,于是转换第二维为树高小于等于 \(j\) 的概率,\(g[i,j]=\sum_{k=1}^if[k,j]\times g[i-k,j]\),这样还少了一部分,即第一棵树有 \(k\) 个点的概率,设为 \(dp\),应再乘上 \(dp[i,k]\)。
最后的问题就是求 \(dp\),对于第 \(i\) 个点,它有 \(i\) 种选择(接在前 \(i-1\) 个点后或新开一棵树),则有 \(dp[i,j]=dp[i-1,j-1]\times\frac{j-1}i+dp[i-1,j]\times\frac{i-j}i\)
带注释的 code
const int N = 205;
int n,mod;
LL ans,inv[N],dp[N][N],f[N][N],g[N][N];
LL Pow(LL x,LL y)
{ LL res=1; for(;y;y>>=1,x=x*x%mod)if(y&1)res=res*x%mod; return res; }
signed main() {
read(n,mod);
For(i,1,n) inv[i] = Pow(i,mod-2);
dp[1][1] = 1;
For(i,2,n) For(j,1,i)
dp[i][j] = (dp[i-1][j-1]*(j-1) + dp[i-1][j]*(i-j))%mod*inv[i]%mod;
f[1][0] = 1; // 单点的深度为0
For(i,0,n) g[0][i] = 1;
For(i,1,n) For(j,0,n) { // j要循环到n,因为g[i][j]=1(j>i)
if( j ) f[i][j] = g[i-1][j-1];
For(k,1,i) g[i][j] = (g[i][j] + dp[i][k]*f[k][j]%mod*g[i-k][j]) %mod;
}
For(i,1,n) ans = (ans + (f[n][i]-f[n][i-1])*i) %mod;
// f[n,i]-f[n,i-1]得到深度为i的概率
write((ans%mod+mod)%mod);
return iocl();
}
y
状压 DP + meet in the middle
bitset
const int N = 95;
int n,m,d;
bitset<N> w[2][N];
int l,ans;
bitset<N> f[1<<12],g[1<<12];
// f[s][i]:从1开始路径为s到i的合法性; g:从2..n开始
signed main() {
read(n,m,d); l = d/2;
For(i,1,m) {
int x,y,z; read(x,y,z);
w[z][x][y] = w[z][y][x] = 1;
}
f[1][1] = 1;
For(i,2,n) g[1][i] = 1;
for(int i = 1; i < 1<<l; ++i)
For(j,1,n) if( f[i][j] ) f[i<<1] |= w[0][j], f[i<<1|1] |= w[1][j];
for(int i = 1; i < 1<<d-l; ++i)
For(j,1,n) if( g[i][j] ) g[i<<1] |= w[0][j], g[i<<1|1] |= w[1][j];
for(int i = 1<<l; i < 1<<l+1; ++i) for(int j = 1<<d-l; j < 1<<d-l+1; ++j)
For(k,1,n) if( f[i][k] && g[j][k] ) { ++ans; break; }
write(ans);
return iocl();
}
z
upd 20210902:
核心:离线,按长度递减的顺序处理询问,同时删除位移绝对值比 \(l\) 小的任务。
代码极其恶心,抄写的我身心俱疲。
带注释的 code
typedef pair<LL,LL> PLL;
const int N = 1e5+5;
int n,q,x[N];
PII l[N];
int m;
LL ans[N]; // ans[0]: l=0的答案
priority_queue<PLL,vector<PLL>,greater<PLL>> pq;
map<LL,LL> mp;
LL calc(LL l) { return ans[0] - (mp.size()-(!mp.empty()&&mp.begin()->se<0)) * l; }
// l<min{x}: 直接算答案(每次可以减少移动距离l,但第一个任务需要向左时不能)
signed main() {
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
read(n,q);
For(i,1,n, lst=0) {
int y; read(y); if( y == lst ) continue;
if( m && ((x[m]<0&&y<lst) || (x[m]>0&&y>lst)) ) x[m] += y-lst;
else x[++m] = y-lst;
lst = y;
} // x转化为位移
For(i,1,q) read(l[i].fi), l[i].se = i; sort(l+1,l+q+1);
For(i,1,m) {
ans[0] += abs(x[i]), mp[i] = x[i];
pq.push(MP(abs(x[i]),i));
}
LL t = 1;
while( !pq.empty() ) {
PII u = pq.top(); pq.pop(); auto it = mp.lower_bound(u.se);
if( it == mp.end() || it->fi != u.se || abs(it->se) != u.fi ) continue;
while( t<=q && abs(it->se) > l[t].fi ) ans[l[t].se] = calc(l[t].fi), ++t;
// 剩余的l都比最小位移绝对值大,尝试删除
if( it != mp.begin() ) {
if( it != prev(mp.end()) ) { // 三合一
auto pre = prev(it), suf = next(it);
ans[0] -= abs(it->se) + abs(pre->se) + abs(suf->se);
it->se += pre->se + suf->se;
ans[0] += abs(it->se);
pq.push(MP(abs(it->se),u.se)), mp.erase(pre), mp.erase(suf);
} else ans[0] -= abs(it->se), mp.erase(it);
} else {
if( it->se > 0 ) { // 向右时可以被l顺便覆盖
if( it != prev(mp.end()) ) { // 二合一
auto suf = next(it);
ans[0] -= abs(it->se) + abs(suf->se);
it->se += suf->se;
if( it->se ) {
ans[0] += abs(it->se);
pq.push(MP(abs(it->se),u.se));
} else mp.erase(it);
mp.erase(suf);
} else ans[0] -= abs(it->se), mp.erase(it);
}
}
}
while( t<=q ) ans[l[t].se] = calc(l[t].fi), ++t;
For(i,1,q) write(ans[i]);
return iocl();
}
20210719 noip20的更多相关文章
- 「 题解」NOIP2021模拟赛(2021-07-19)
小兔的话 欢迎大家在评论区留言哦~ D - 矩阵 简单题意 一个 \(i * i\) 的 \(01\) 矩阵,若满足 每一行 和 每一列 都满足 恰好 有 \(2\) 个位置是 \(1\) 时,称为 ...
- noip20
T1 首先,这个插球,就是森林中连点,考虑dp,我们设 \(dp_{i,j}\) 表示有i个点的森林,有j个点在第一颗树中的概率,转移时考虑第i个点是否在第一颗子树里,转移方程: \[dp_{i,j} ...
- 调用免费API查询全年工作日、周末、法定节假日、节假日调休补班数据
前言 日常开发中,难免会用到判断今天是工作日.周末.法定节假日.节假日调休补班做一些业务处理,例如:仅在上班时间给用户推送消息.本文记录调用免费API查询全年工作日.周末.法定节假日.节假日调休补班数 ...
- AspNetCore&MassTransit Courier实现分布式事务
在之前的一篇博文中,CAP框架可以方便我们实现非实时.异步场景下的最终一致性,而有些用例总是无法避免的需要在实时.同步场景下进行,可以借助Saga事务来解决这一困扰.在一些博文和仓库中也搜寻到了.Ne ...
- 从零学习SpringSecurity
一.简介 SpringSecurity是一个功能强大且高度可定制的身份验证和访问控制框架,和spring项目整合更加方便. 二.核心功能 认证(Authentication):指的是验证某个用户能否访 ...
- 日常shell练习
2021-07-19 1.echo的使用 1.1 echo -n 表示不换行输出 # echo输出会自动换行,换行输出两个1 echo 1 echo 1 # 不换行输出,不换行输出两个1 echo - ...
- 2021record
2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...
- 基于Spring MVC + Spring + MyBatis的【超市会员管理系统】
资源下载: https://download.csdn.net/download/weixin_44893902/22035329 一. 语言和环境 实现语言:JAVA语言. 使用:MyEclipse ...
- 基于Java swing+mysql+eclipse的【水电费管理系统】
本项目为前几天收费帮学妹做的一个项目,Java swing项目,在工作环境中基本使用不到,但是很多学校把这个当做编程入门的项目来做,故分享出本项目供初学者参考. CSDN9.9赞助下载: https: ...
随机推荐
- PHP5.6.6上运行 ecshop 2.7.3常见问题处理
ecshop在在PHP5.6.6版本以后,有了很多细微的变化.而ECSHOP官方更新又太慢,发现这些问题后也不及时升级,导致用户安装使用过程中错误百出. 整理一下我遇到的问题希望对你们能有些帮组也为了 ...
- 论文笔记:(2021CVPR)PAConv: Position Adaptive Convolution with Dynamic Kernel Assembling on Point Clouds
目录 摘要 1.引言 2.相关工作 将点云映射到常规二维或三维栅格(体素) 基于MLPs的点表示学习 基于点卷积的点表示学习 动态卷积和条件卷积 3.方法 3.1 回顾 3.2 动态内核组装 Weig ...
- OpenGL学习笔记(四)纹理
目录 要完成的纹理效果 纹理环绕方式 纹理过滤 多级渐远纹理 加载与创建纹理 stb_image库的使用方法 生成纹理对象 应用纹理 纹理单元 参考资料:OpenGL中文翻译 要完成的纹理效果 纹理是 ...
- 『go成长之路』 defer 作用、典型用法以及多个defer调用顺序,附加defer避坑点,拿来吧你
预习内容 defer 的作用有哪些? 多个 defer 的执行顺序是怎样的? defer,return,函数返回值 三者之间的执行顺序 defer的作用 go中的defer是延迟函数,一般是用于释放资 ...
- 原生ajax练习-post&xml
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 多次面试被拒,‘宅家苦修’30天,终获美团offer(含字节跳动/阿里/腾讯等大厂面试题整理)
背景:双非渣本. 今年由于疫情,上半年一直在家里.2月份本来无忧无虑,呆在家里不给国家添乱的时候,发现身边的同学找到了大厂的offer.心里开始有点慌张.本来想在3月份如果能回到学校,就开始考研之路, ...
- ElementUi 表单验证失败后 页面滚动到表单验证失败位置
1.应用场景 当进行长表单验证时 用户填写到了单子的最下面 可是已经滚动过去的部分单子验证失败 为了友好的用户体验 这时候就需要滚动到验证失败位置 2.解决思路 elementUi本身并没有提供相关获 ...
- 用notepad2代替notepad
Windows自带的notepad.exe功能比较弱,notepad2是一个比较好的替代方案,但在任何系统调用notepad的时候都能用notepad2代替并不是一件容易的事,下面是一个解决方法: h ...
- Using Evernote with Wine on Mint
Install Evernote Install Evernote in Wine: wine Evernote_xxx.exe; Backup Evernote Database File Loca ...
- vue源码解析之响应式原理
关于defineReactive等使用细节需要自行了解 一些关键知识点 $mount时 会 new Watcher 把组件的 updateComponent 方法传给watcher 作为getter ...