原文链接www.cnblogs.com/zhouzhendong/p/UOJ196.html

题解

先离散化,设离散化后的值域为 $[0,m]$ 。

首先把问题转化一下,变成:对于每一个位置 $i$ ,求出它最终不超过 $j$ 的方案数。

考虑如何求这个东西。

对于一个固定的 $j$ ,考虑一个这样的过程:

初始时,有若干个区间,两两不相交,且区间内的元素都小于等于 $j$ ,而且每一个区间都不能在满足条件的基础上,向左右任意一侧扩张。

考虑其中的一个区间 $[L,R]$ ,如果出现了操作使得它的边界变成了比 $j$ 大的值,那么这个区间会缩小。

考虑对于他的所有子区间 $[x,y]$ ,求出 $q$ 次操作之后, $[L,R]$ 缩小成 $[x,y]$ 的方案数。

这东西显然可以列出 DP 方程:设 $dp[x][i][j]$ 表示当前进行了 $x$ 次操作,初始区间变成 $[i,j]$ 方案数,则:

$$\begin{eqnarray*}dp[x][i][j]&=&\left (\frac{(i-1)i}2 + \frac{(j-i+1)(j-i+2)}2 + \frac {(n-j)(n-j+1)}2 \right )dp[x-1][i][j] \\ &+& \sum_{k=L}^{i-1} dp[x-1][k][j] \cdot (k-1) \\ &+& \sum_{k=j+1}^R  dp[x-1][i][k] \cdot (n-k) \end{eqnarray*}$$

这样的话看上去总的运算量是 $O(n^4)$ 的。

考虑到题目中保证数据随机。

那么,如果对序列建一棵笛卡尔树,那么这个笛卡尔树是基本平衡的,可以近似看做一棵满二叉树。

而我们要求的区间只有 $O(n)$ 个,是对于每一个位置 $i$ ,到它两侧第一个比他大的数之前,这个范围内的区间答案。

这个东西放在笛卡尔树上就是子树的size,而对一个区间进行dp的复杂度是 $O(q\cdot size^2)$ ,又由于这棵笛卡尔树可以近似看做满二叉树,所以求个和就可以发现复杂度总和是 $O(n^2q)$ 的,可以通过此题。

代码

  1. #pragma GCC optimize("Ofast","inline")
  2. #include <bits/stdc++.h>
  3. #define clr(x) memset(x,0,sizeof (x))
  4. #define For(i,a,b) for (int i=a;i<=b;i++)
  5. #define Fod(i,b,a) for (int i=b;i>=a;i--)
  6. #define pb(x) push_back(x)
  7. #define mp(x,y) make_pair(x,y)
  8. #define fi first
  9. #define se second
  10. #define _SEED_ ('C'+'L'+'Y'+'A'+'K'+'I'+'O'+'I')
  11. #define outval(x) printf(#x" = %d\n",x)
  12. #define outvec(x) printf("vec "#x" = ");for (auto _v : x)printf("%d ",_v);puts("")
  13. #define outtag(x) puts("----------"#x"----------")
  14. #define outarr(a,L,R) printf(#a"[%d...%d] = ",L,R);\
  15. For(_v2,L,R)printf("%d ",a[_v2]);puts("");
  16. using namespace std;
  17. typedef long long LL;
  18. typedef unsigned long long ULL;
  19. typedef vector <int> vi;
  20. LL read(){
  21. LL x=0,f=0;
  22. char ch=getchar();
  23. while (!isdigit(ch))
  24. f|=ch=='-',ch=getchar();
  25. while (isdigit(ch))
  26. x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
  27. return f?-x:x;
  28. }
  29. const int N=405,mod=1e9+7,INF=mod;
  30. void Add(int &x,int y){
  31. if ((x+=y)>=mod)
  32. x-=mod;
  33. }
  34. void Del(int &x,int y){
  35. if ((x-=y)<0)
  36. x+=mod;
  37. }
  38. int Pow(int x,int y){
  39. int ans=1;
  40. for (;y;y>>=1,x=(LL)x*x%mod)
  41. if (y&1)
  42. ans=(LL)ans*x%mod;
  43. return ans;
  44. }
  45. int n,q;
  46. int a[N];
  47. int val[N][N];
  48. vector <int> Ha;
  49. int tmp[N][N];
  50. int dp[2][N][N];
  51. void solve(int L,int R,int t){
  52. For(i,L,R)
  53. For(j,i,R)
  54. dp[0][i][j]=0;
  55. dp[0][L][R]=1;
  56. For(c,1,q){
  57. int _0=(c^1)&1,_1=c&1;
  58. For(i,L,R)
  59. For(j,i,R)
  60. dp[_1][i][j]=(LL)tmp[i][j]*dp[_0][i][j]%mod;
  61. For(j,L,R){
  62. int s=0;
  63. For(i,L,j){
  64. Add(dp[_1][i][j],s);
  65. Add(s,(LL)dp[_0][i][j]*(i-1)%mod);
  66. }
  67. }
  68. For(i,L,R){
  69. int s=0;
  70. Fod(j,R,i){
  71. Add(dp[_1][i][j],s);
  72. Add(s,(LL)dp[_0][i][j]*(n-j)%mod);
  73. }
  74. }
  75. }
  76. For(j,L,R){
  77. int s=0;
  78. For(i,L,j){
  79. Add(s,dp[q&1][i][j]);
  80. Add(val[i][t],s);
  81. }
  82. }
  83. }
  84. int main(){
  85. n=read(),q=read();
  86. For(i,1,n)
  87. a[i]=read(),Ha.pb(a[i]);
  88. sort(Ha.begin(),Ha.end());
  89. Ha.erase(unique(Ha.begin(),Ha.end()),Ha.end());
  90. For(i,1,n)
  91. a[i]=lower_bound(Ha.begin(),Ha.end(),a[i])-Ha.begin();
  92. For(i,1,n)
  93. For(j,1,n)
  94. tmp[i][j]=(i-1)*i/2+(j-i+1)*(j-i+2)/2+(n-j)*(n-j+1)/2;
  95. a[0]=a[n+1]=Ha.size();
  96. For(t,0,(int)Ha.size()-1){
  97. int L=0,Mx=0;
  98. For(R,1,n+1)
  99. if (a[R]<=t)
  100. Mx=max(Mx,a[R]);
  101. else {
  102. if (L+1<=R-1){
  103. if (Mx<t){
  104. For(i,L+1,R-1)
  105. Add(val[i][t],val[i][t-1]);
  106. }
  107. else
  108. solve(L+1,R-1,t);
  109. }
  110. L=R,Mx=0;
  111. }
  112. }
  113. For(i,1,n){
  114. int ans=0;
  115. Fod(j,(int)Ha.size()-1,1)
  116. Del(val[i][j],val[i][j-1]);
  117. For(j,0,(int)Ha.size()-1)
  118. Add(ans,(LL)val[i][j]*Ha[j]%mod);
  119. printf("%d ",ans);
  120. }
  121. puts("");
  122. return 0;
  123. }

  

UOJ#196. 【ZJOI2016】线段树 概率期望,动态规划的更多相关文章

  1. UOJ#299. 【CTSC2017】游戏 线段树 概率期望 矩阵

    原文链接www.cnblogs.com/zhouzhendong/p/UOJ299.html 前言 不会概率题的菜鸡博主做了一道概率题. 写完发现运行效率榜上的人都没有用心卡常数——矩阵怎么可以用数组 ...

  2. UOJ#467. 【ZJOI2019】线段树 线段树,概率期望

    原文链接www.cnblogs.com/zhouzhendong/p/ZJOI2019Day1T2.html 前言 在LOJ交了一下我的代码,发现它比选手机快将近 4 倍. 题解 对于线段树上每一个节 ...

  3. LOJ#3043.【ZJOI2019】 线段树 线段树,概率期望

    原文链接www.cnblogs.com/zhouzhendong/p/ZJOI2019Day1T2.html 前言 在LOJ交了一下我的代码,发现它比选手机快将近 4 倍. 题解 对于线段树上每一个节 ...

  4. hdu-5805 NanoApe Loves Sequence(线段树+概率期望)

    题目链接: NanoApe Loves Sequence Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 262144/131072 ...

  5. 洛谷P2221 [HAOI2012]高速公路(线段树+概率期望)

    传送门 首先,答案等于$$ans=\sum_{i=l}^r\sum_{j=i}^r\frac{sum(i,j)}{C_{r-l+1}^2}$$ 也就是说所有情况的和除以总的情况数 因为这是一条链,我们 ...

  6. Luogu3352 ZJOI2016 线段树 概率、区间DP

    传送门 考虑对于每一个位置\(i\),计算所有可能的结果出现的概率. 定义一个区间\([l,r]\)为对于\(x\)的极大区间,当且仅当\(\max \limits _{i=l}^r \{a_i\} ...

  7. Luogu4927 梦美与线段树(线段树+概率期望)

    每个节点被经过的概率即为该区间和/总区间和.那么所需要计算的东西就是每个节点的平方和了.修改对于某个节点的影响是使其增加2sum·l·x+l2x2.那么考虑对子树的影响,其中Σl2是定值,修改后Σsu ...

  8. P3924 康娜的线段树(期望)

    P3924 康娜的线段树 看起来$O(nlogn)$可过其实由于巨大常数是无法通过的 $O(nlogn)$:70pts 我们手玩样例发现 线段树上某个节点的期望值$f[o]=(f[lc]+f[rc]) ...

  9. bzoj 4574: [Zjoi2016]线段树

    Description 小Yuuka遇到了一个题目:有一个序列a_1,a_2,?,a_n,q次操作,每次把一个区间内的数改成区间内的最大值,问 最后每个数是多少.小Yuuka很快地就使用了线段树解决了 ...

随机推荐

  1. 前端安全类——CSRF/XSS

    CSRF 概念:跨站请求伪造 全称:Cross-site request forgery 攻击原理:网站中某一个接口存在漏洞,用户在注册网站登录过 防御措施: 1.Token验证:引诱链接只会自动携带 ...

  2. 【Unity编辑器】UnityEditor多重弹出窗体与编辑器窗口层级管理

    一.简介 最近马三为公司开发了一款触发器编辑器,对于这个编辑器策划所要求的质量很高,是模仿暴雪的那个触发器编辑器来做的,而且之后这款编辑器要作为公司内部的一个通用工具链使用.其实,在这款触发器编辑器之 ...

  3. PowerEdge R430 机架式服务器安装( Ubuntu server 14.04.1 、PHP5.5.9、PHP-redis2.8、Phalcon3.1)

    未解决问题:换成静态路由的话,怎么就 apt-get udpate 出现错误信息! 解决办法:么有设置网关 一.Ubuntu 系统下载地址: https://certification.ubuntu. ...

  4. django --视图装饰器

  5. 【opencv实践】边缘检测

    边缘检测: 一.canny算子 Canny边缘检测根据对信噪比与定位乘积进行测度,得到最优化逼近算子,也就是Canny算子.类似与 LoG 边缘检测方法,也属于先平滑后求导数的方法. 二.canny算 ...

  6. 20164305 徐广皓 Exp3 免杀原理与实践

    免杀原理及基础问题回答 实验内容 任务一:正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil-evasion,自己利用shellcode编程等免杀工具或技巧 使用msf编码器生 ...

  7. C# 处理文件,视频,音频,压缩包下载

    文章介绍了通过HttpWebRequest和HttpWebResponse实现视频下载的功能:首先HttpWebRequest类利用HTTP 协议和服务器交互,再由HttpWebResponse返回来 ...

  8. Apple Tree POJ - 2486 (树形dp)

    题目链接: D - 树形dp  POJ - 2486 题目大意:一颗树,n个点(1-n),n-1条边,每个点上有一个权值,求从1出发,走V步,最多能遍历到的权值 学习网址:https://blog.c ...

  9. 论文翻译:Neural Networks With Few Multiplications

    目录 Abstract 1. Introduction 2.Related Work 3.Binary And Ternary Connect 3.1 BINARY CONNECT REVISITED ...

  10. spring boot 业务场景简单,代码完整的demo们

    源码地址:https://github.com/zhzhair/spring-boot-examples.git 开发环境:windows,jdk8,spring boot2.1.4