博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
P4769 [NOI2018]冒泡排序(dp)
阅读量:6913 次
发布时间:2019-06-27

本文共 1679 字,大约阅读时间需要 5 分钟。

日常膜拜shadowice巨巨的

//minamoto#include
#define R register#define ll long long#define fp(i,a,b) for(R int i=a,I=b+1;i
I;--i)#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)template
inline bool cmax(T&a,const T&b){return a
'9'||ch<'0')(ch=='-')&&(f=-1); for(res=ch-'0';(ch=getc())>='0'&&ch<='9';res=res*10+ch-'0'); return res*f;}const int N=6e5+5,P=998244353;inline int add(R int x,R int y){return x+y>=P?x+y-P:x+y;}inline int dec(R int x,R int y){return x-y<0?x-y+P:x-y;}inline int mul(R int x,R int y){return 1ll*x*y-1ll*x*y/P*P;}int ksm(R int x,R int y){ R int res=1; for(;y;y>>=1,x=mul(x,x))if(y&1)res=mul(res,x); return res;}int fac[N<<1],inv[N<<1],mn[N],a[N];int n;inline int C(R int n,R int m){return m<0?0:mul(fac[n],mul(inv[m],inv[n-m]));}inline int S(R int n,R int m){return m>n?0:dec(C((n<<1)-m,n-m),C((n<<1)-m,n-m-1));}struct BI{ int c[N]; inline void upd(R int x,R int y){for(;x<=n;x+=x&-x)c[x]+=y;} inline int query(R int x){R int res=0;for(;x;x-=x&-x)res+=c[x];return res;} inline void clr(){fp(i,1,n)c[i]=0;}}bi;int main(){// freopen("testdata.in","r",stdin); fac[0]=inv[0]=1;fp(i,1,(N<<1)-5)fac[i]=mul(fac[i-1],i); inv[(N<<1)-5]=ksm(fac[(N<<1)-5],P-2);fd(i,(N<<1)-6,1)inv[i]=mul(inv[i+1],i+1); int T=read(); while(T--){ n=read();fp(i,1,n)a[i]=read(); fp(i,1,n)bi.upd(a[i],1); mn[n]=a[n];fd(i,n-1,1)mn[i]=min(mn[i+1],a[i]); int mx=0,cmx=0,ans=0; fp(i,1,n){ if(cmx>mn[i])break;ans=add(ans,S(n-i+1,bi.query(max(mx,a[i]))+1)); if(a[i]

转载于:https://www.cnblogs.com/bztMinamoto/p/10266597.html

你可能感兴趣的文章
学生管理系统报错(一)
查看>>
使用 Live555 搭建流媒体服务器
查看>>
第十四周(OOP版电子词典)
查看>>
网络基础知识小小说
查看>>
linux lsof命令详解
查看>>
POJ 1163 The Triangle【dp+杨辉三角加强版(递归)】
查看>>
vue如何在路由跳转的时候更新组件
查看>>
Java多线程(二)
查看>>
《深入浅出数据分析》读后具体解释
查看>>
C++中的异常安全性
查看>>
Xcode中的变量模板(variable template)的使用方法
查看>>
java POI实现Excel单元格数据换行
查看>>
python3第一次作业
查看>>
国内物联网平台初探(三) ——QQ物联·智能硬件开放平台
查看>>
Python开源框架、库、软件和资源大集合
查看>>
透过IL看C# 开篇
查看>>
那是什么进程 —— wmpnscfg.exe是什么? 它为何运行?
查看>>
g++宏扩展
查看>>
《http权威指南》阅读笔记(七)
查看>>
webservices base64编码
查看>>