考场

去年考过这场,心态直接爆炸

T1 一眼

T2 当初是我讲的,基本都记得(flag)

T3 只记得是树形 DP,但觉得 rush 完前两题后用大量时间应该能搞出来

结果 T2 写了好久,还写假了。。。

T3 没时间写了,直接骗分。交题的时候发现链上的分写的不对,没改完

res

rk3 100+20+1

T2 仅有的分是本来要用来对拍的暴力,而且还是靠数据水拿的

rk1 ycx 100+85+100

rk2 wcr 100+2+37

u

考场写了 std 做法,和去年不一样

考场代码
const int N = 2e3+5;
int n,q; LL ans,a[N][N],b[N][N]; signed main() {
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
read(n,q);
while( q-- ) {
int r,c,l,s; read(r,c,l,s);
a[r][c] += s, a[r+l][c+l] -= s;
b[r+l][c] -= s, b[r+l][c+l] += s;
}
For(i,1,n) For(j,1,n) a[i][j] += a[i-1][j-1];
For(i,1,n) For(j,1,n) a[i][j] += a[i-1][j];
For(i,1,n) For(j,1,n) b[i][j] += b[i-1][j]+b[i][j-1]-b[i-1][j-1];
// For(i,1,n) {
// For(j,1,n) printf("%d ",a[i][j]+b[i][j]);
// putchar(10);
// }
For(i,1,n) For(j,1,n) ans ^= a[i][j] + b[i][j];
write(ans);
return iocl();
}

v

题意就没理解。暴力、手玩都挂了

一个移除的白球对答案的贡献是不一样的,如果它在第一次操作移除,那就是 \(\frac 1n\),第二次则是 \(\frac1{n(n-1)}\),依次类推。因此不能算出最大移除白球总数后乘 \(\frac{n!}{(n-k)!}\)

code(与去年有所不同)
const int N = 35, S = 5e7;
int n,m,s; double ans,f[S+1];
map<int,double> g; int cut(int x,int i) { return ((x&(~((1<<(i+1))-1)))>>1) | (x&((1<<i)-1)); }
bool get(int x,int i) { return x & (1<<i); } double dfs(int i,int s) {
if( i > m ) return 0;
if( s <= S && f[s] != -1 ) return f[s];
else if( g.count(s) ) return g[s];
double res = 0;
int l = (n-i+1)/2;
for(int j = 0; j < l; ++j)
res += 2 * max(dfs(i+1,cut(s,j))+get(s,j),
dfs(i+1,cut(s,n-i-j))+get(s,n-i-j));
if( (n-i+1) & 1 ) res += dfs(i+1,cut(s,l))+get(s,l);
res /= n-i+1;
(s<=S ? f[s] : g[s]) = res;
return res;
} signed main() {
read(n,m);
For(i,1,n) s |= (readc()=='W')<<(i-1);
s |= 1<<n;
For(i,0,S) f[i] = -1;
printf("%.8lf",dfs(1,s));
return 0;
}

w

当初就没理解清楚。

这题对边有限制,而树形 DP 都是基于节点的,因此要进行类似树剖维护边权的边转点操作,\(f[u][1/0]\) 保存的是 \(u\) 到父亲的边翻/不翻的最小奇数度点数和最少翻转边数。转移时 \(x,y\) 也保存的是如果有从 \(u\) 的子树中伸到 \(u\) 的路径,两两配对后剩下1/0条的答案。

计算 \(f[u][0/1]\) 时根据 \(w(fa,u)\) 的情况分类讨论,决策有:

f[u][0]: 从子树伸上来的边在 \(u\) 处结束;子树伸上来的边都两两配对了

f[u][1]: 从子树伸上来的边继续向上伸;新开一条路径

code
const int N = 1e5+5;
int n,mm=1,head[N],to[N*2],w[N*2],nxt[N*2]; const PII inf = MP(1e9,1e9);
PII f[N][2]; PII operator + (const PII &x,const PII &y) { return MP(x.fi+y.fi,x.se+y.se); } void adde(int x,int y,int z) {
to[++mm] = y, w[mm] = z, nxt[mm] = head[x], head[x] = mm;
to[++mm] = x, w[mm] = z, nxt[mm] = head[y], head[y] = mm;
}
void dfs(int u,int fa,int op) {
PII x = inf, y = MP(0,0);
for(int i = head[u], v; i; i = nxt[i]) if( (v=to[i]) != fa ) {
dfs(v,u,w[i]);
PII xx = min(x+f[v][0],y+f[v][1]), yy = min(x+f[v][1],y+f[v][0]);
x = xx, y = yy;
}
if( op == 1 ) f[u][0] = inf;
else f[u][0] = min(x+MP(1,0),y);
if( !op ) f[u][1] = inf;
else f[u][1] = min(x+MP(0,1),y+MP(1,1));
} signed main() {
read(n);
for(int i = 1; i < n; ++i) {
int x,y,a,b; read(x,y,a,b);
adde(x,y,b!=2 ? a!=b : 2);
}
dfs(1,0,2);
printf("%d %d",f[1][0].fi/2,f[1][0].se);
return iocl();
}

反思

原题大赛,考得很烂

首先是心态上,开场发现是原题就心态不稳。T1 记忆犹新,快速写完 T1 并拍上是对的,T2 大概记得做法而没做出来就是因为太浮躁,没好好读题,而有些细节不记得也没读出来。调 T2 的时候一直在尝试想起原来的做法而不是仔细找现在的 bug。以后遇到原题大概回忆一下,就当新题来做。

其次在题目上,T3 这种 DP 一直是我的弱项,改题时发现当时就没理解透彻,导致这次还是不会做。对于这种当时没有理解的题,要记下来,事后多看、多想。写过的博客不要写完就完了,以后每次模拟赛前看一篇。

最后是策略上,在 20min 拍上 T1 后,绝大部分时间都用来写 T2,导致 T3 没有思考且只写了很少时间,写的时候也在想 T2,最终挂掉了链上的分。以后遇到这种很久调不出来的题就先跳了,不要因小失大。

实话实说,考原题的话我自认是最强的。但从上次考出一道并暴毙之后没有采取什么措施,反而 ycx 做得很好,这次就体现出来了。

好好反思,不要重蹈覆辙

20210718 noip19的更多相关文章

  1. noip19

    sb\(O(n^{2})\)传参 T1 暴力一会儿就码好,结果.. 祭奠一下死去的代码 died #include<cstdio> #define MAX 1010 #define re ...

  2. 20210716考试-NOIP19

    u,v,w. 这场考过. T1 u 差分裸题 #include<bits/stdc++.h> using namespace std; const int N=5000; int n,m; ...

  3. 调用免费API查询全年工作日、周末、法定节假日、节假日调休补班数据

    前言 日常开发中,难免会用到判断今天是工作日.周末.法定节假日.节假日调休补班做一些业务处理,例如:仅在上班时间给用户推送消息.本文记录调用免费API查询全年工作日.周末.法定节假日.节假日调休补班数 ...

  4. vue项目使用Echarts制作项目工期甘特图

    目录 1,前言 2,布局和数据部分 3,制作甘特图 1,前言 项目迭代过程中,碰上一个需求,要求用甘特图的方式显示项目的工期进度,开完会我赶紧搜索一下甘特图是啥东东,大概了解之后,做出了如下样式 Ec ...

  5. Java 中节省 90% 时间的常用的工具类

    前言 你们有木有喜欢看代码的领导啊,我的领导就喜欢看我写的代码,有事没事就喜欢跟我探讨怎么写才最好,哈哈哈...挺好. 今天我们就一起来看看可以节省 90% 的加班时间的第三方开源库吧,第一个介绍的必 ...

  6. 接口自动化测试之httprunner初探

    ❝ 今天来介绍一个python的一个开源项目:httprunner,接口自动化工具.第一次输入,难免有不周到的地方,轻喷~ ❞ 介绍: HttpRunner是一个简单优雅但功能强大的 HTTP(S) ...

  7. 2、二进制安装K8s 之 部署ETCD集群

    二进制安装K8s 之 部署ETCD集群 一.下载安装cfssl,用于k8s证书签名 二进制包地址:https://pkg.cfssl.org/ 所需软件包: cfssl 1.6.0 cfssljson ...

  8. 2021record

    2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...

  9. 基于Spring MVC + Spring + MyBatis的【医院就诊挂号系统】

    资源下载:https://download.csdn.net/download/weixin_44893902/21727306 一.语言和环境 1.实现语言: JAVA语言. 2.环境要求: MyE ...

随机推荐

  1. 大数据学习(02)——HDFS入门

    Hadoop模块 提到大数据,Hadoop是一个绕不开的话题,我们来看看Hadoop本身包含哪些模块. Common是基础模块,这个是必须用的.剩下常用的就是HDFS和YARN. MapReduce现 ...

  2. SVG和Canvas的区别?

    什么是SVG? SVG(可缩放矢量图形)编辑可缩放矢量图形是基于可扩展标记语言(标准通用标记语言的子集),用于描述二维矢量图形的一种图形格式.它由万维网联盟制定,是一个开放标准. 什么是 Canvas ...

  3. for循环中++i和i++的区别

    语法 for (语句1; 语句2; 语句3) { 被执行的代码块 } 语句 1 在循环(代码块)开始前执行 语句 2 定义运行循环(代码块)的条件 语句 3 在循环(代码块)已被执行之后执行(这就是循 ...

  4. MVC配置原理-源码

    目录 举例 修改SpringBoot的默认配置 全面接管SpringMVC 参考链接 在进行项目编写前,我们还需要知道一个东西,就是SpringBoot对我们的SpringMVC还做了哪些配置,包括如 ...

  5. 003 PCI Express体系结构(三)

    一.PCI总线的存储器读写总线事务 总线的基本任务是实现数据传送,将一组数据从一个设备传送到另一个设备,当然总线也可以将一个设备的数据广播到多个设备.在处理器系统中,这些数据传送都要依赖一定的规则,P ...

  6. Java调用阿里云短信接口发送手机验证码

    前五步可参考阿里云服务文档:https://help.aliyun.com/document_detail/59210.html?spm=a2c4g.11174283.4.1.2b152c42DoJ7 ...

  7. 解密优酷智能生产技术,看 AI 赋能内容数字化

    2021 年,随着社会节奏的加快,用户碎片化消费时间不断增加,当前短视频的消费用户规模已超 7.73 亿人,短视频的市场规模超过 2000 亿元.短视频行业发展迅速,但也存在低质内容泛滥,精品内容稀缺 ...

  8. 栈编程和函数控制流: 从 continuation 与 CPS 讲到 call/cc 与协程

    原标题:尾递归优化 快速排序优化 CPS 变换 call/cc setjmp/longjmp coroutine 协程 栈编程和控制流 讲解 本文为部分函数式编程的扩展及最近接触编程语言控制流的学习和 ...

  9. SpringCloud升级之路2020.0.x版-23.订制Spring Cloud LoadBalancer

    本系列代码地址:https://github.com/HashZhang/spring-cloud-scaffold/tree/master/spring-cloud-iiford 我们使用 Spri ...

  10. Vue 如何实现一个底部导航栏组件

    参考网址: https://www.jianshu.com/p/088936b7b1bd/ Vue 如何实现一个底部导航栏组件 可以看到父组件是知道我点击了底部TabBar的哪个item的. 实现 实 ...