题目链接

BZOJ5058

题解

可以发现任意两个位置\(A,B\)最终位置关系的概率是相等的

如果数列是这样:

CCCCACCCCBCCCC

那么最终有\(7\)种位置关系

\((A,B)\)

\((A,C)\)

\((B,A)\)

\((B,C)\)

\((C,A)\)

\((C,B)\)

\((C,C)\)

手玩出\(7 \times 7\)的转移矩阵,矩乘后即可得到各种位置关系的概率

然后枚举\(B\),用树状数组维护与\(A\)有关的量组合计算即可

写得极烦

放开我我没疯

我只是计数时把大小弄反了

  1. #include<algorithm>
  2. #include<iostream>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cstdio>
  6. #include<vector>
  7. #include<queue>
  8. #include<cmath>
  9. #include<map>
  10. #define LL long long int
  11. #define REP(i,n) for (int i = 1; i <= (n); i++)
  12. #define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
  13. #define cls(s,v) memset(s,v,sizeof(s))
  14. #define mp(a,b) make_pair<int,int>(a,b)
  15. #define cp pair<int,int>
  16. #define lbt(x) (x & -x)
  17. using namespace std;
  18. const int maxn = 500005,maxm = 100005,INF = 0x3f3f3f3f,P = 1000000007;
  19. inline int read(){
  20. int out = 0,flag = 1; char c = getchar();
  21. while (c < 48 || c > 57){if (c == '-') flag = 0; c = getchar();}
  22. while (c >= 48 && c <= 57){out = (out << 1) + (out << 3) + c - 48; c = getchar();}
  23. return flag ? out : -out;
  24. }
  25. struct Matrix{
  26. int s[7][7],n,m;
  27. Matrix(){cls(s,0); n = m = 0;}
  28. }M,F0,F;
  29. inline Matrix operator *(const Matrix& a,const Matrix& b){
  30. Matrix c;
  31. if (a.m != b.n) return c;
  32. c.n = a.n; c.m = b.m;
  33. for (int i = 0; i < c.n; i++)
  34. for (int j = 0; j < c.m; j++)
  35. for (int k = 0; k < a.m; k++)
  36. c.s[i][j] = (c.s[i][j] + 1ll * a.s[i][k] * b.s[k][j] % P) % P;
  37. return c;
  38. }
  39. inline Matrix qpow(Matrix a,LL b){
  40. Matrix re; re.n = re.m = a.n;
  41. for (int i = 0; i < re.n; i++) re.s[i][i] = 1;
  42. for (; b; b >>= 1,a = a * a)
  43. if (b & 1) re = re * a;
  44. return re;
  45. }
  46. inline int qpow(int a,int b){
  47. int re = 1;
  48. for (; b; b >>= 1,a = 1ll * a * a % P)
  49. if (b & 1) re = 1ll * re * a % P;
  50. return re;
  51. }
  52. inline void Add(int& x,int y){x += y; x >= P ? x -= P : 0;}
  53. int n,K,A[maxn];
  54. void init(int* a,int A,int B,int C,int D,int E,int F,int G){
  55. a[0] = A; a[1] = B; a[2] = C; a[3] = D; a[4] = E; a[5] = F; a[6] = G;
  56. }
  57. void cal(){
  58. M.n = M.m = 7;
  59. int a = 1ll * (n - 2) * (n - 3) / 2 % P,b = ((1ll * n * (n - 1) / 2 % P - n) % P + P) % P;
  60. int c = n - 2,d = n - 3,e = ((1ll * n * (n - 1) / 2 % P - 4) % P + P) % P;
  61. init(M.s[0],a,1,1,0,0,1,0);
  62. init(M.s[1],c,b,0,1,1,0,1);
  63. init(M.s[2],1,0,a,1,1,0,0);
  64. init(M.s[3],0,1,c,b,0,1,1);
  65. init(M.s[4],0,1,c,0,b,1,1);
  66. init(M.s[5],c,0,0,1,1,b,1);
  67. init(M.s[6],0,d,0,d,d,d,e);
  68. F0.n = 7; F0.m = 1; F0.s[0][0] = 1;
  69. F = qpow(M,K) * F0;
  70. }
  71. int s[maxn],pos[maxn],vpos[maxn];
  72. void add(int* s,int u,int v){while (u <= n) s[u] = (s[u] + v) % P,u += lbt(u);}
  73. int query(int* s,int u){int re = 0; while (u) re = (re + s[u]) % P,u -= lbt(u); return re;}
  74. void work(){
  75. int ans = 0;
  76. int p1 = F.s[0][0],p2 = F.s[1][0],p3 = F.s[2][0],p4 = F.s[3][0];
  77. int p5 = F.s[4][0],p6 = F.s[5][0],p7 = F.s[6][0],inv = qpow(n - 2,P - 2);
  78. int inv2 = qpow(2,P - 2);
  79. LL sumf = 0,sumg = 0,a,b,fa,fb,ga,gb;
  80. for (int i = 1; i <= n; i++){
  81. a = query(s,A[i]); fa = query(pos,A[i]); ga = query(vpos,A[i]);
  82. b = i - 1 - a; fb = sumf - fa,gb = sumg - ga;
  83. Add(ans,1ll * b * p1 % P);
  84. Add(ans,(1ll * a * (n - i) % P + 1ll * b * (i - 2) % P) * inv % P * p2 % P);
  85. Add(ans,1ll * a * p3 % P);
  86. Add(ans,1ll * (fb + ga) % P * inv % P * p4 % P);
  87. Add(ans,(1ll * a * (i - 2) % P + 1ll * b * (n - i) % P % P) % P * inv % P * p5 % P);
  88. Add(ans,1ll * (gb + fa) % P * inv % P * p6 % P);
  89. add(s,A[i],1); add(pos,A[i],i - 1); add(vpos,A[i],n - i - 1);
  90. sumf += i - 1; sumg += n - i - 1;
  91. }
  92. Add(ans,1ll * n * (n - 1) / 2 % P * inv2 % P * p7 % P);
  93. printf("%d\n",(ans % P + P) % P);
  94. }
  95. int main(){
  96. n = read(); K = read();
  97. REP(i,n) A[i] = read();
  98. cal();
  99. work();
  100. return 0;
  101. }

BZOJ5058 期望逆序对 【矩乘 + 组合数学 + 树状数组】的更多相关文章

  1. 洛谷 P1908 逆序对 Label:归并排序||树状数组 不懂

    题目描述 猫猫TOM和小老鼠JERRY最近又较量上了,但是毕竟都是成年人,他们已经不喜欢再玩那种你追我赶的游戏,现在他们喜欢玩统计.最近,TOM老猫查阅到一个人类称之为“逆序对”的东西,这东西是这样定 ...

  2. BZOJ 3295 [CQOI2011]动态逆序对 (三维偏序CDQ+树状数组)

    题目大意: 题面传送门 还是一道三维偏序题 每次操作都可以看成这样一个三元组 $<x,w,t>$ ,操作的位置,权值,修改时间 一开始的序列看成n次插入操作 我们先求出不删除时的逆序对总数 ...

  3. P1966 火柴排队——逆序对(归并,树状数组)

    P1966 火柴排队 很好的逆序对板子题: 求的是(x1-x2)*(x1-x2)的最小值: x1*x1+x2*x2-2*x1*x2 让x1*x2最大即可: 可以证明将b,c数组排序后,一一对应的状态是 ...

  4. 逆序对__归并排序__树状数组 Inversions SGU - 180

    There are N integers (1<=N<=65537) A1, A2,.. AN (0<=Ai<=10^9). You need to find amount o ...

  5. [luogu3157][bzoj3295][CQOI2011]动态逆序对【cdq分治+树状数组】

    题目描述 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计整个序列的逆序 ...

  6. 康拓展开 & 逆康拓展开 知识总结(树状数组优化)

    康拓展开 : 康拓展开,难道他是要飞翔吗?哈哈,当然不是了,康拓具体是哪位大叔,我也不清楚,重要的是 我们需要用到它后面的展开,提到展开,与数学相关的,肯定是一个式子或者一个数进行分解,即 展开. 到 ...

  7. poj3067 Japan 树状数组求逆序对

    题目链接:http://poj.org/problem?id=3067 题目就是让我们求连线后交点的个数 很容易想到将左端点从小到大排序,如果左端点相同则右端点从小到大排序 那么答案即为逆序对的个数 ...

  8. 牛客练习赛38 D 题 出题人的手环 (离散化+树状数组求逆序对+前缀和)

    链接:https://ac.nowcoder.com/acm/contest/358/D来源:牛客网 出题人的手环 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K,其他 ...

  9. bzoj1831 逆序对 (dp+树状数组)

    注意到,所有的-1应该是一个不降的序列,否则不会更优那就先求出来不是-1的的逆序对个数,然后设f[i][j]表示第i个-1放成j的前i个-1带来的最小逆序对数量这个可以树状数组来求 #include& ...

随机推荐

  1. Unity优化方向——优化Unity游戏中的脚本(译)

    原文地址:https://unity3d.com/cn/learn/tutorials/topics/performance-optimization/optimizing-scripts-unity ...

  2. 用UGUI制作可根据手指位置自动定位的隐形遥杆

    之前写过遥杆怎么做,这里依然用的是之前的方法,就不介绍了. 之前玩过<蜡烛人>,发现手游版的<蜡烛人>的遥杆是看不见的,手指直接在屏幕左边滑动人物就可以移动,可能是为了增强沉浸 ...

  3. move.js运动插件

    move.js 运动插件是一款针对元素动画效果的插件.可以运用此插件制作出各类元素效果. 插件GitHub地址:https://github.com/visionmedia/move.js 下面整理学 ...

  4. 2019网易笔试题C++--丰收

    题目描述 又到了丰收的季节,恰好小易去牛牛的果园里游玩. 牛牛常说他多整个果园的每个地方都了如指掌,小易不太相信,所以他想考考牛牛. 在果园里有N堆苹果,每堆苹果的数量为ai,小易希望知道从左往右数第 ...

  5. could not launch process: decoding dwarf section info at offset 0x0: too short

    Fabric调试异常 作者在使用chaincode进行智能合约开发的过程中,使用Goland + Golang + win10_X64作为开发环境: GoLand 2018.1.4 Build #GO ...

  6. 从零开始的Python学习Episode 21——socket基础

    socket基础 网络通信要素: A:IP地址   (1) 用来标识网络上一台独立的主机 (2) IP地址 = 网络地址 + 主机地址(网络号:用于识别主机所在的网络/网段.主机号:用于识别该网络中的 ...

  7. Linux(Contos7.5)环境搭建之JDK1.8安装(二)

    1.下载安装包 wget -p 目录 url包地址 2.解压安装包 tar -xzvf  文件 -C 指定目录 3.修改名称 mv jdk1.8.0_45 jdk1.8 4.配置环境变量 vim /e ...

  8. yum安装lnmp

    python其他知识目录 1.安装LNMP之前要安装EPEL,以便安装源以外的软件,如Nginx,phpMyAdmin等. yum install epel-release 提示:EPEL,即Extr ...

  9. 获取session

    HttpServletRequest request = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()) ...

  10. 冲刺One之站立会议8 /2015-5-21

    今天我们把聊天界面做了优化和改进,主要实现了聊天的功能.显示了正在进行通信的成员列表,和当前状态,是否连通和正常通信,大体完成了预期的目标. 燃尽图8