不妨假设$x\le y$,可以通过翻转整个格子序列来调整

令$a_{i}$​​为$i$​​到$y$​​的期望步数,显然有方程$a_{i}=\begin{cases}0&(i=y)\\\frac{\sum_{j=i+1}^{n}a_{j}}{n-i}+1&(i<y)\\\frac{\sum_{j=1}^{i-1}a_{j}}{i-1}+1&(i>y)\end{cases}$​​​

将其写成递推的形式,即
$$
\forall 1\le i\le y-2,a_{i}=\frac{n-i-1}{n-i}(a_{i+1}-1)+\frac{1}{n-i}a_{i+1}+1=a_{i+1}+\frac{1}{n-i}
$$
进一步的,即有$a_{i}=a_{y-1}+\sum_{j=i}^{y-2}\frac{1}{n-j}$​​,代入$a_{y+1}$的式子即
$$
a_{y+1}=\frac{\sum_{i=1}^{y}a_{i}}{y}+1=\frac{a_{y-1}+\sum_{i=1}^{y-2}(a_{y-1}+\sum_{j=i}^{y-2}\frac{1}{n-j})}{y}+1=k_{1}a_{y-1}+C_{1}
$$
(其中$k_{1}=\frac{y-1}{y},C_{1}=\frac{\sum_{i=1}^{y-2}\sum_{j=i}^{y-2}\frac{1}{n-j}}{y}+1$​​​,显然为常数,且不难​​预处理得到)

类似地,也可以得到$a_{y-1}=\frac{n-y}{n-y+1}a_{y+1}+\frac{\sum_{i=y+2}^{n}\sum_{j=y+2}^{i}\frac{1}{j-1}}{n-y+1}+1$​​(同样记为$a_{y-1}=k_{2}a_{y+1}+C_{2}$​)​​

将前者代入后者,即$a_{y-1}=k_{2}(k_{1}a_{y-1}+C_{1})+C_{2}$​​​​​​,解得$a_{y-1}=\frac{k_{2}C_{1}+C_{2}}{1-k_{1}k_{2}}$​​,将$k_{1}$​​和$k_{2}$​​的式子代入,不难得到$1-k_{1}k_{2}=\frac{n}{y(n-y+1)}$​​​

再根据前面,也即有答案$a_{x}=\frac{y(n-y+1)(k_{2}C_{1}+C_{2})}{n}+\sum_{i=x}^{y-2}\frac{1}{n-i}$(注意特判$x=y$和$y=n$)

综上,$o(n)$​​​​​预处理后即可$o(1)$​​​​​计算,时间复杂度为$o(n+T)$​​​​​

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 2000005
4 #define mod 1000000007
5 #define ll long long
6 int t,n,x,y,ans,inv[N],S1[N],S2[N];
7 int main(){
8 inv[0]=inv[1]=S1[0]=S2[0]=1;
9 for(int i=2;i<N;i++)inv[i]=(ll)(mod-mod/i)*inv[mod%i]%mod;
10 for(int i=1;i<N;i++)S1[i]=(S1[i-1]+inv[i])%mod;
11 for(int i=1;i<N;i++)S2[i]=(S2[i-1]+S1[i])%mod;
12 scanf("%d",&t);
13 while (t--){
14 scanf("%d%d%d",&n,&x,&y);
15 if (x>y)x=n-x+1,y=n-y+1;
16 if (x==y){
17 printf("0\n");
18 continue;
19 }
20 if (y==n){
21 printf("%d\n",(1+S1[n-x]-S1[n-y+1]+mod)%mod);
22 continue;
23 }
24 int k1=(ll)(y-1)*inv[y]%mod,k2=(ll)(n-y)*inv[n-y+1]%mod;
25 int C1=((S2[n-1]-S2[n-y+1]+mod)%mod-(ll)(y-2)*S1[n-y+1]%mod+mod)%mod;
26 int C2=((S2[n-1]-S2[y]+mod)%mod-(ll)(n-y-1)*S1[y]%mod+mod)%mod;
27 C1=((ll)C1*inv[y]+1)%mod,C2=((ll)C2*inv[n-y+1]+1)%mod;
28 ans=(ll)y*(n-y+1)%mod*(((ll)k2*C1+C2)%mod)%mod*inv[n]%mod;
29 ans=(ans+(S1[n-x]-S1[n-y+1]+mod)%mod)%mod;
30 printf("%d\n",ans);
31 }
32 return 0;
33 }

最新文章

  1. 让 Generator 自启动
  2. 为什么要 MySQL 迁移到 Maria DB
  3. docker gitlab,redmine,etc development enviroments
  4. MySQL数据库主从复制
  5. linux/shell sort命令
  6. SVM整理
  7. mysql主配置文件my.cnf详细说明
  8. CURL传输与获取功能
  9. iOS 10 语音识别Speech Framework详解
  10. YOLO: 3 步实时目标检测安装运行教程 [你看那条狗,好像一条狗!]
  11. &lt;抽象工厂&gt;比&lt;工厂方法&gt;多了啥
  12. 使用tcpreply对DPDK进行压力测试(一台主机,2张网卡压测)
  13. HDU5950 Recursive sequence (矩阵快速幂)
  14. PAT Basic 1069. 微博转发抽奖(20)
  15. 从零开始学 Web 之 DOM(七)事件冒泡
  16. 写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和
  17. sql server与C#中的字符串相等等效写法
  18. CxGrid筛选自动添加百分号和默认旧的滚动条样式
  19. Linux基础命令---sum,cksum
  20. DropDownList绑定数据的几种方式

热门文章

  1. Codeforces Round #747 (Div. 2)
  2. 题解 「BJOI2018 治疗之雨」
  3. Redis 基础数据类型重温
  4. NX Open 切削层加载
  5. Vue2源码解读 - 响应式原理及简单实现
  6. 大闸蟹的项目分析——CSDN APP
  7. 【SDOI2014】数数(补)
  8. vs2015 MSB600 &quot;inf2cat.ext&quot;已退出,代码为2
  9. accept error: Too many open files
  10. 数组中出现次数超过一半的数字 牛客网 剑指Offer