bzoj4574:Zjoi2016线段树 dp
//Achen
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<vector>
#include<cstdio>
#include<queue>
#include<cmath>
using namespace std;
const int N=;
#define mo 1000000007
int n,q,x[N],y[N],rank[N];
int cnt[N],A[N][N];long long dp[][N][N],sum[N][N]; bool mycmp(int a,int b) { return x[a]<x[b]; } void init() {
scanf("%d%d",&n,&q);
for(int i=;i<=n;i++)scanf("%d",&x[i]);
for(int i=;i<=n;i++)y[i]=i;
sort(y+,y++n,mycmp);
for(int i=;i<=n;i++)rank[y[i]]=i;
return ;
} #define dp(i,j,k) dp[(i)%2][j][k]
void solve(int l,int r,int now) {
for(int i=l;i<=r;i++) for(int j=l;j<=r;j++)dp(,i,j)=dp(,i,j)=;
dp(,l,r)=;
long long ct;
for(int k=;k<=q;k++) {
for(int i=l;i<=r;i++) {
ct=;
for(int j=r;j>=i;j--) {
dp(k,i,j)=ct; ct=(ct+dp(k-,i,j)*(n-j))%mo;
}
}
for(int j=l;j<=r;j++) {
ct=;
for(int i=l;i<=j;i++) {
dp(k,i,j)=(dp(k,i,j)+ct)%mo; ct=(ct+dp(k-,i,j)*(i-));
}
}
for(int i=l;i<=r;i++) {
for(int j=i;j<=r;j++) {
dp(k,i,j)=(dp(k,i,j)+(dp(k-,i,j)*A[i][j]))%mo;
}
}
}
for(int i=l;i<=r;i++) {
ct=;
for(int j=r;j>=i;j--) {
ct=(ct+dp(q,i,j));
sum[j][rank[now]]=(ct+sum[j][rank[now]])%mo;
}
}
return ;
} int main() {
#ifdef DEBUG
freopen(".in","r",stdin);
freopen(".out","w",stdout);
#endif
init();
int l,r;
for(int i=;i<=n;i++) cnt[i]=i*(i+)/;
for(int i=;i<=n;i++) for(int j=i;j<=n;j++) A[i][j]=cnt[i-]+cnt[n-j]+cnt[j-i+];
memset(sum,,sizeof(sum));
for(int i=;i<=n;i++) {
l=r=i;
while(l && x[l]<=x[i])l--; while(r<=n && x[r]<=x[i])r++;
solve(l+,r-,i);
}
int ans;
for(int i=;i<=n;i++) {
ans=;
for(int j=;j<=n;j++) {
if(!sum[i][j])continue;
for(int u=;u<j;u++)sum[i][j]=(sum[i][j]-sum[i][u])%mo;
ans=((long long)ans+1ll*x[y[j]]*sum[i][j])%mo;
}
ans=(ans+mo)%mo;
if(i!=n) printf("%d ",ans);else printf("%d",ans);
} return ;
}
bzoj4574:Zjoi2016线段树 dp的更多相关文章
- BZOJ4574 [Zjoi2016]线段树
比较厉害的dp. 网上题解都是利用了随机的条件,用了一个$O(n^4)$的dp,这里简单说一下. 用f(x,i,l,r)表示经过前i轮操作,[l,r]的所有数<=x,且l-1和r+1都>x ...
- Tsinsen A1219. 采矿(陈许旻) (树链剖分,线段树 + DP)
[题目链接] http://www.tsinsen.com/A1219 [题意] 给定一棵树,a[u][i]代表u结点分配i人的收益,可以随时改变a[u],查询(u,v)代表在u子树的所有节点,在u- ...
- HDU 3016 Man Down (线段树+dp)
HDU 3016 Man Down (线段树+dp) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- lightoj1085 线段树+dp
//Accepted 7552 KB 844 ms //dp[i]=sum(dp[j])+1 j<i && a[j]<a[i] //可以用线段树求所用小于a[i]的dp[j ...
- [CF 474E] Pillars (线段树+dp)
题目链接:http://codeforces.com/contest/474/problem/F 意思是给你两个数n和d,下面给你n座山的高度. 一个人任意选择一座山作为起始点,向右跳,但是只能跳到高 ...
- HDU-3872 Dragon Ball 线段树+DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3872 题意:有n个龙珠按顺序放在一列,每个龙珠有一个type和一个权值,要求你把这n个龙珠分成k个段, ...
- HDU4521+线段树+dp
题意:在一个序列中找出最长的某个序列.找出的序列满足题中的条件. 关键:对于 第 i 个位置上的数,要知道与之相隔至少d的位置上的数的大小.可以利用线段树进行统计,查询.更新的时候利用dp的思想. / ...
- Codeforces Round #343 (Div. 2) D - Babaei and Birthday Cake 线段树+DP
题意:做蛋糕,给出N个半径,和高的圆柱,要求后面的体积比前面大的可以堆在前一个的上面,求最大的体积和. 思路:首先离散化蛋糕体积,以蛋糕数量建树建树,每个节点维护最大值,也就是假如节点i放在最上层情况 ...
- Special Subsequence(离散化线段树+dp)
Special Subsequence Time Limit: 5 Seconds Memory Limit: 32768 KB There a sequence S with n inte ...
随机推荐
- Wed Nov 01 13:03:16 CST 2017 WARN: Establishing SSL connection without server's identity verification is not recommended.
报错:Wed Nov 01 13:03:16 CST 2017 WARN: Establishing SSL connection without server's identity verifica ...
- JS 常用的两个客户端输出方法
document.write(str) 描述:在网页的<body>标记,输出str的内容. document意思“文档”,就是整个网页了. document是一个文档对象,代表 ...
- Java lambda尝鲜
最近Java 11都出来了,java 8 的很多新特性还没用过,比如接口可以有方法体啦,default默认方法. 当然最大的特性就是支持函数式编程了.Java 8 提供了lambda表达式和方法引用来 ...
- elementUI中的隐藏组件el-scrollbar
细心的人儿都会发现elementUI官网的滚动条样式优美,但是elementUI中并未给出这个滚动条组件,打开调试页面发现用到了el-scrollbar.问一下度娘发现早就有前辈们发现了这个问题并给出 ...
- idea 提交拉取代码,解决冲突
继上两篇文章,本篇重点.所用的都是项目实际操作 提交代码 新建文件提交代码 idea自动提醒你是否加入到本地缓存(点击add就是添加如果不添加提交不上去事后需要手动提交 ps:快捷键是ctrl+alt ...
- 自己写一个依赖注入容器Container
前言:在平时的写代码中为了解耦.方便扩展,经常使用一些DI容器(如:Autofac.Unity),那是特别的好用. 关于它的底层实现代码 大概是这样. 一.使用依赖注入的好处 关于使用依赖注入创建对象 ...
- typeerror: __init__() missing 2 required positional arguments: 'inputs' and 'outputs'
1 问题描述 使用下边这条命令去检查 TensorFlow Object Detection API是否正确安装: python object_detection\builders\model_bui ...
- golang 高效字符串拼接
https://blog.csdn.net/u012210379/article/details/45110705 虽然方便,但是使用+=操作符并不是在一个循环中往字符串末尾追加字符串最有效的方式,一 ...
- Python-面向对象之高级进阶
目录 classmethod与staticmethod 面向对象高级 isinstance.issubclass 反射 魔法方法(类内置方法) 单例模式 classmethod与staticmetho ...
- poj3167- Cow Patterns
传送门 两个串相等定义为串中每一位排序后的相对大小相等. 一位相等等价于这一位前面比他小的和等于他的数的个数相等. 那么用kmp,比较的时候比较这两个个数就可以了. 一开始很瓜地想,询问一段区间内比我 ...