2018 CCPC 湘潭邀请赛 & 2018 JSCPC

Problem A

 

Problem B

 

Problem C

这题用主席树轻松解决

可以二分答案,每次查询;也可以直接开个全局变量在主席树上二分;

时间复杂度$O(nlog^{2}n)$或$O(nlogn)$

 

Problem D

设$f[i][j]$为$j$个球分成$i$段的乘积

首先不管环,考虑这样一个链,黑白黑白黑白黑白

反正就是保证:黑白段数相同,首尾两段颜色不一样

但是他是一个环,也就是,首尾两个球的颜色可以相同,那我们把最后那段的最后一个球,放到第一的位置的前面,

然后把倒数第二个球,再放到最前面,直到最后那段只剩下一个球了,也就是说这一条链的答案 可以产生最后一段长度的贡献

那这条链对答案的贡献就是$s_{1} * s_{2} * s_{3} * ... * s_{i - 1} * s_{i} * s{i}$

也就是最后一段平方一下,其他都不变

于是就DP另一个东西,设$g[i][j]$为$j$个球分成$i$段, 最后那段要平方一下的所有方案的乘积和

最后枚举段数,乘法原理搞一下就好了。

DP的时候用滚动数组优化,处理询问的时候对询问离线。

时间复杂度$O(n^{2})$

 

 

Problem E

 

Problem F

 

Problem G

 

Problem H

 

Problem I

设$f1[i]$为以$a[i]$结尾的最长上升子序列

设$f2[i]$为以$a[i]$开头的最长上升子序列

忽略掉$0$

首先注意到一个事实,假设不考虑$0$,原序列的LIS长度为$L$,总有$f(x) = L$ 或 $f(x) = L + 1$

对于某个正整数$a[i]$,考虑他前面的最右边的某个$0$,考虑这个数之前的所有正整数$a[j]$

我们要找到这样一个$j$,满足以下条件:

$1、f1[j] + f2[i] = L$;

$2、a[j] + 1 < a[i]$;

$3、a[j]$要最小。

找到这样的$a[j]$之后,对于所有的满足$a[j] < k < a[i]$的$k$,有$f(k) = L + 1$。

枚举$a[i]$, 在$O(logn)$的时间内完成上面的事情,然后差分标记一下即可。

时间复杂度$O(nlogn)$

 

Problem J

 

Problem K

 

posted @ 2018-05-19 23:32  cxhscst2  阅读(430)  评论(0编辑  收藏  举报