正题

题目链接:https://www.luogu.com.cn/problem/P3352


题目大意

\(n\)个数字的一个序列,每次随机选择一个区间让这个区间所有数等于这个区间的最大值,重复\(q\)次,对每个位置求所有情况下这个位置的值的和。

\(1\leq n,q\leq 400\),保证数据随机


解题思路

设\(f_{k,l,r}\)表示使用了\(k\)次目前覆盖了极大区间\(l,r\)时的方案。

这个极大区间就是无法继续向左右扩展(就是左右两边是边界或者比这个区间内所有数都大),不然相同的方案会统计入不同的数组导致算重。

然后每次我们找一个数字开始向左右扩展到极大区间进行\(dp\),然后\(dp\)方程是

\[f_{k,l,r}=f_{k-1,l,r}\times g_{l,r}+\sum_{i=L}^{l-1}f_{k-1,i,r}+\sum_{i=r+1}^{R}f_{k-1,l,i+1}
\]

也就是固定端点的情况下扩展极大区间,因为是反过来的所以这样是对的。

然后记录一个\(dp\)数组\(ans_{i,j}\)表示数字\(i\)至少为第\(j\)小的情况数,这个每次\(dp\)后都可以统计。

上面每个\(dp\)区间相当于笛卡尔树上的区间,因为数据随机,所以每个位置只会计算\(log\)次。

时间复杂度\(O(nq^2+n^3)\)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=410,P=1e9+7;
ll n,q,a[N],b[N],rk[N],f[2][N][N],ans[N][N],cnt[N];
void solve(ll x,ll L,ll R){
for(ll i=L;i<=R;i++)
for(ll j=i;j<=R;j++)
f[0][i][j]=f[1][i][j]=0;
f[0][L][R]=1;
for(ll k=1;k<=q;k++){
for(ll i=L;i<=R;i++)
for(ll j=i;j<=R;j++)
f[k&1][i][j]=f[~k&1][i][j]*(cnt[j-i+1]+cnt[i-1]+cnt[n-j]);
for(ll i=L;i<=R;i++){
ll buf=0;
for(ll j=R;j>=i;j--){
(f[k&1][i][j]+=buf)%=P;
(buf+=f[~k&1][i][j]*(n-j))%=P;
}
}
for(ll j=L;j<=R;j++){
ll buf=0;
for(ll i=L;i<=j;i++){
(f[k&1][i][j]+=buf)%=P;
(buf+=f[~k&1][i][j]*(i-1))%=P;
}
}
}
for(ll i=L;i<=R;i++){
ll buf=0;
for(ll j=R;j>=i;j--){
(buf+=f[q&1][i][j])%=P;
(ans[j][rk[x]]+=buf)%=P;
}
}
return;
}
signed main()
{
scanf("%lld%lld",&n,&q);
for(ll i=1;i<=n;i++)cnt[i]=i*(i+1)/2;
for(ll i=1;i<=n;i++){
scanf("%lld",&a[i]);
b[i]=a[i];
}
sort(b+1,b+1+n);
ll m=unique(b+1,b+1+n)-b-1;
for(ll i=1;i<=n;i++)rk[i]=lower_bound(b+1,b+1+m,a[i])-b;
for(ll i=1;i<=n;i++){
ll L=i,R=i;
while(L>1&&a[L-1]<a[i])L--;
while(R<n&&a[R+1]<a[i])R++;
solve(i,L,R);
}
for(ll i=1;i<=n;i++){
ll sum=0;
for(ll j=1;j<=n;j++){
if(!ans[i][j]){continue;}
for(ll k=1;k<j;k++)
(ans[i][j]+=P-ans[i][k])%=P;
(sum+=ans[i][j]*b[j]%P)%=P;
}
printf("%lld ",sum);
}
return 0;
}

P3352-[ZJOI2016]线段树【dp】的更多相关文章

  1. bzoj4574:Zjoi2016线段树 dp

    传送门 题解传送门 //Achen #include<algorithm> #include<iostream> #include<cstring> #includ ...

  2. Tsinsen A1219. 采矿(陈许旻) (树链剖分,线段树 + DP)

    [题目链接] http://www.tsinsen.com/A1219 [题意] 给定一棵树,a[u][i]代表u结点分配i人的收益,可以随时改变a[u],查询(u,v)代表在u子树的所有节点,在u- ...

  3. HDU 3016 Man Down (线段树+dp)

    HDU 3016 Man Down (线段树+dp) Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja ...

  4. lightoj1085 线段树+dp

    //Accepted 7552 KB 844 ms //dp[i]=sum(dp[j])+1 j<i && a[j]<a[i] //可以用线段树求所用小于a[i]的dp[j ...

  5. [CF 474E] Pillars (线段树+dp)

    题目链接:http://codeforces.com/contest/474/problem/F 意思是给你两个数n和d,下面给你n座山的高度. 一个人任意选择一座山作为起始点,向右跳,但是只能跳到高 ...

  6. HDU-3872 Dragon Ball 线段树+DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3872 题意:有n个龙珠按顺序放在一列,每个龙珠有一个type和一个权值,要求你把这n个龙珠分成k个段, ...

  7. HDU4521+线段树+dp

    题意:在一个序列中找出最长的某个序列.找出的序列满足题中的条件. 关键:对于 第 i 个位置上的数,要知道与之相隔至少d的位置上的数的大小.可以利用线段树进行统计,查询.更新的时候利用dp的思想. / ...

  8. Codeforces Round #343 (Div. 2) D - Babaei and Birthday Cake 线段树+DP

    题意:做蛋糕,给出N个半径,和高的圆柱,要求后面的体积比前面大的可以堆在前一个的上面,求最大的体积和. 思路:首先离散化蛋糕体积,以蛋糕数量建树建树,每个节点维护最大值,也就是假如节点i放在最上层情况 ...

  9. Special Subsequence(离散化线段树+dp)

    Special Subsequence Time Limit: 5 Seconds      Memory Limit: 32768 KB There a sequence S with n inte ...

  10. hdu 4117 GRE Words (ac自动机 线段树 dp)

    参考:http://blog.csdn.net/no__stop/article/details/12287843 此题利用了ac自动机fail树的性质,fail指针建立为树,表示父节点是孩子节点的后 ...

随机推荐

  1. python 日期、时间处理,各种日期时间格式/字符串之间的相互转换究竟是怎样的?

    模块函数说明 ''' date 日期对象,常用的属性有year,month,day time 时间对象,常用的属性有hour,minute,second,毫秒 datetime 日期时间对象,常用的属 ...

  2. 5、二进制安装K8s 之 部署kube-scheduler

    二进制安装K8s之部署kube-scheduler 1.创建配置文件 cat > /data/k8s/config/kube-scheduler.conf << EOF KUBE_S ...

  3. springmvc学习日志四

    一.回顾 1.文件上传 1.1引入fileupload的jar包 1.2在springmvc的配置文件中引入CommonsMutilpartResolver文件上传解析器 1.3在控制层在写入代码 2 ...

  4. ProjectEuler 008题

    题目: The four adjacent digits in the 1000-digit number that have the greatest product are 9 9 8 9 = 5 ...

  5. docker安装与配置gitlab详细过程

    docker安装与配置gitlab详细过程 1.打开网易镜像中心 https://c.163yun.com/hub#/m/home/ 2.搜索gitlab,获取下载地址.例如:docker pull  ...

  6. Java特性和优势

    Java特性和优势 简单性 面向对象性 可移植性 高性能 分布式 动态性 多线程 安全性 健壮性

  7. Zookeeper:进大厂不得不学的分布式协同利器!

    大家好,我是冰河~~ 最近,有很多小伙伴让我更新一些Zookeeper的文章,正好也趁着清明假期把之前自己工作过程当中总结的Zookeeper知识点梳理了一番,打算写一个[精通Zookeeper系列] ...

  8. Appium问题解决方案(10)- Original error: Swipe did not complete successfully

    背景 从搜索页面返回首页之后,执行  swipe 滑动操作,但是报错了,如上图 解决方法 只需要在第一次 swipe 之前加个 sleep,强制等待即可 备注 这种解决方案其实不好,强制等待能少用就少 ...

  9. Jenkins持续集成接口压测

    步骤 自动化压测- jmeter + shell Jenkins与jmeter压测,环境要求 自动压测运行逻辑 Jmeter输出压力测试报告 压测报告与Jenkins集成 Jenkins任务:源码同步 ...

  10. Git:为Git Bash.exe设置默认起始目录的两种方式(start in、~/.bashrc)

    在协作开发的过程中,我们经常要进行一些项目的上传拉取操作. 在无数次不厌其烦的打开关闭 Git Bash 后,我实在忍受不了作为一个程序员还要每次都要进行如下的小白操作了 cd /d/my-proje ...