2018.11.21:

1、[BZOJ 4868][SHOI 2017]

从后往前枚举最后位置即可,如果$A<B$,用尽可能多的$A$替换$B$操作

Tip:很大的$C$可能爆$longlong$,注意特判掉与$C$相乘超过上限的数!

2、[BZOJ 4872][SHOI 2017]

首先每个灯最多按一次,接下来发现正确按取集合唯一,只不过顺序任意

设$dp[i]$表示从正确按取$i$个到$i-1$个的期望次数,则有:

$dp[i]=\frac{i}{n}+\frac{n-i}{n}*(dp[i]+dp[i+1]+1)$,$res=\sum_{i=k+1}^{cnt} dp[i]$

Tip:注意最后答案加上$k$!

3、[BZOJ 4869][SHOI 2017]

EXT欧拉定理套路(题解传送门

4、[BZOJ 4870][SHOI 2017]

矩阵快速幂(题解传送门

2018.11.22:

1、[AGC 004F]

又是$Atcoder$的思维神题……(题解传送门

2、[BZOJ 2326][P 3216]

递推式:$dp[i]=dp[i-1]*10^{dgt}+i$

$dgt$相同时明显可以上带常数项的矩阵快速幂,然后再根据$dgt$分个段就行了

Tip:看$hzwer$程序学了下慢速乘,就是为了防止爆$longlong$用快速幂的方式做乘法

3、[BZOJ 1560][P 4056]

这种题一般都能先推出一个性质:

由于无负权,$a-b-c$一定比$a-c$优

这样就能每次只从每列最下面转移,复杂度$O(n*m)$

不过如果将式子列出来发现是能$O(m*m)$斜率优化转移的:

$dp[i]=dp[j]-rowdist_j-(i-j)^2+w$,维护个上凸壳就行了

4、[BZOJ 1597][P 2900]

先将矩形排序去掉完全包含的矩形

发现剩下的矩形必然是$x$递增,$y$递减的,从而方便$dp$:

$dp[i]=min{dp[j]+a[i]*b[j+1]}$

将$dp[j]=y,dp[i]=b,-a[i]=k,b[j+1]=x$就能维护下凸壳斜率优化了

5、[BZOJ 4011][P 3244]

在$DAG$上单独考虑每个点选哪条来边即可,就是$\prod in[i]$

加了一条边去掉含环的情况即可:钦定环,方案数就是$\frac{\prod in[i]}{\prod in[cir[i]]}$

拓扑序$dp$或$dfs$算环都行

6、[BZOJ 3612][P 4104]

首先模型转换为取$k$个$[-n,n]$内不同的数和为0的方案数

接下来用整数划分$dp$来计算仅考虑正数时的方案数:

这个都不会系列,传送门

$dp[i][j]=dp[i-j][j]+dp[i-j][j-1]$,(前者为不含1,后者为恰好仅含1个1)

一般此类$dp$都按是否含1来转移!由于数不同,因此仅含1个1时要先铺一层

同时为了保证每个数在范围内,在$i>n$时每次都要减去恰有一个数为$n+1$时的方案数

(之所以值考虑$n+1$是因为每次选的数最多加1)

最后按照是否选$0$分类统计答案即可

2018.11.23:

1、[BZOJ 3611][P 4103]

虚树裸题,一般此类询问多但限定了询问点总和的题目考虑虚树,只利用询问点及其$LCA$

由于$n$个点的$LCA$个数最多为$n-1$个,则能保证虚树的复杂度为$\sum n$

(由于$lca(a,b)!=lca(a,c)$则$lca(b,c)=lca(a,c)$,则可通过每次一个$lca$至少合并两个点来证明)

这样此题用栈维护右链建出虚树后直接树形$dp$就行了

2、[BZOJ 1096][P 2120]

预处理出前缀和,然后斜率优化$dp$即可

3、[BZOJ 2436][P 1973]

一般此类多次询问必须有一项选/不选时最值的题目 都要预处理前/后缀情况

此题先预处理出$pre[i][j],suf[i][j]$表示前/后$i$个时刻$A$选了$j$个时$B$最多选多少个

那么无限制下$res=max{min(i,pre[tot][i])}$

否则钦定一个包含$[x[i],y[i]]$的区间$[L,R]$都给$A$,再考虑两边的最优分配

设$f[L][R]$表示该区间最优解,枚举$A$在$[1,L]$中选了$k1$个,在$[R,tot]$中选了$k2$个

此时$f[L][R]=max{min(k1+k2+num[L][R],pre[L][k1]+suf[R][k2])}$

对于此类双变量最值先控制一个变量$k1$单调

发现在$k1$固定下的最优$k2$随$k1$增加而减少,从而利用该单调性做到$O(n^3)$算$f$

4、[BZOJ 1023][P 4244]

竟然还是第一次写仙人掌上$dp$……

对于仙人掌一般都是桥和环分别处理

设$f[i]$表示$i$向非父边方向延伸出的最长链,如果是桥则用$f[i]+f[to]+1$更新$res$

否则单独处理环:用$max(f[i]+f[j]+dist(i,j))$更新$res$(其中$dist$表示两点在环上的较短距离)

为了$O(n)$求最值,将环赋值一遍后用单调递减的单调栈维护$f[i]-i$

每次将距离超过一半的弹出,栈顶即使当前点的之前最优点

注意:

1、算完环后注意更新返回点的$f$值!

2、$tarjan$遇到已访问点用$dfn$而非$low$来更新!

5、[BZOJ 2002][P 2387]

$LCT$(题解传送门)

6、[BZOJ 3669][P 3203]

简化版$LCT$板子……

2018.11.23:

1、[BZOJ 2957][P 4198]

2018.11.26:

1、[BZOJ 3997][P 3203]

$Dilworth$定理+$dp$

2、[BZOJ 4871][SHOI2017]

大分类树形$dp$……

3、[AGC 006A]

4、[AGC 006B]

发现性质:有两个相邻的相同就能一直保持

因此构造$n-1,n$/$n,n+1$相同即可

2018.11.27:

1、[Codeforces 713C]

$codeforces$评论题解:传送门

2、[BZOJ 2743][P 4113]

3、[BZOJ 2809][P 1552]

4、[AGC 006C]

期望的线性性+置换

5、[AGC 006D]

2018.11.28:

1、[AGC 006E]

2、[AGC 006F]

3、[ARC 067C]

4、[ARC 067D]

5、[ARC 067E]

学了两天文化课……咕咕咕

2018.12.1:

1、[BZOJ 4873][SHOI2017]

最大权闭合子图

2018.12.2:

1、[P 2742]

练了下$Andrew$和$Graham$求凸包

2、[ZROI 503]

3、[ZROI 504]

4、[ZROI 505]

模拟赛题解见Contest Review

随机推荐

  1. Mysql中的primary key 与auto_increment

    mysql> create table cc(id int auto_increment); ERROR (): Incorrect table definition; there can be ...

  2. 如何使用curl命令指定ip访问url

    有时我们需要测试一个url,但域名并没解析,这时为了一个简单的测试而写host或去做域名解析,显然这并不高效,而有些域名甚至是正式的域名,因此我们可有使用curl命令进行测试 方法一 curl url ...

  3. Ubuntu每次开机后提示:检测到系统程序出现问题的解决方法

    首先,错误报告存放位置: cd /var/crash/ ls //可以查看错误报告 1 2 sudo rm /var/crash/* //删除该目录下的所有文件 1 但是,这只是删除掉的是错误报告,如 ...

  4. [ python ] 匿名函数和高阶函数

    匿名函数 描述:    关键字 lambda 定义的函数    语法: 函数名 = lambda 参数:返回值 返回值:    函数返回结果值 实例: 一个参数的匿名函数: func = lambda ...

  5. BootStarp的form表单的基本写法

    代码如下: <!DOCTYPE html> <html> <head> <title>BootStrap的基础入门</title> < ...

  6. Visual Tracking with Fully Convolutional Networks

    http://blog.csdn.net/carrierlxksuper/article/details/48918297 传统的跟踪方法依赖低维的人工特征,但这种特征对目标的外观变化等问题不够鲁棒. ...

  7. HDU 3342 Legal or Not(拓扑排序判断成环)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3342 题目大意:n个点,m条有向边,让你判断是否有环. 解题思路:裸题,用dfs版的拓扑排序直接套用即 ...

  8. 关于语义化版本(semantic versioning or SemVer)

    1  为什么要有SemVer? SemVer用来规范组件之间的依赖版本,它使用一个版本号来传递出组件的API的变化情况. 在理解这规范之后,看一眼依赖包的版本号,就知道API的变化(兼容性)程度,方便 ...

  9. EF – 6.一对一关联

    5.6.6 <一对一关联概述>  5.6.7 <一对一关联CRUD演示>  在两讲视频中,首先介绍了数据库中一对一关联表的设计规范,接着通过实例介绍了如何合适Entity Fr ...

  10. Eolinker----全局变量的不同场景使用

    因为目前eolinker的API自动化测试不支持“构造参数”,因此针对“全局变量”的使用在不同的场景下,可采用不同的方式实现,但是一个参数既然设计成为了全局变量,那么在接口中使用时尽量保证书写风格一致 ...