不妨假设$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 }

[hdu7000]二分的更多相关文章

  1. BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]

    1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 8748  Solved: 3835[Submi ...

  2. BZOJ 2756: [SCOI2012]奇怪的游戏 [最大流 二分]

    2756: [SCOI2012]奇怪的游戏 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 3352  Solved: 919[Submit][Stat ...

  3. 整体二分QAQ

    POJ 2104 K-th Number 时空隧道 题意: 给出一个序列,每次查询区间第k小 分析: 整体二分入门题? 代码: #include<algorithm> #include&l ...

  4. [bzoj2653][middle] (二分 + 主席树)

    Description 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整. 给你一个长度为n的序列s. 回答Q个这样的询问:s的左端点在[a,b ...

  5. [LeetCode] Closest Binary Search Tree Value II 最近的二分搜索树的值之二

    Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ...

  6. [LeetCode] Closest Binary Search Tree Value 最近的二分搜索树的值

    Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ...

  7. jvascript 顺序查找和二分查找法

    第一种:顺序查找法 中心思想:和数组中的值逐个比对! /* * 参数说明: * array:传入数组 * findVal:传入需要查找的数 */ function Orderseach(array,f ...

  8. BZOJ 1305: [CQOI2009]dance跳舞 二分+最大流

    1305: [CQOI2009]dance跳舞 Description 一次舞会有n个男孩和n个女孩.每首曲子开始时,所有男孩和女孩恰好配成n对跳交谊舞.每个男孩都不会和同一个女孩跳两首(或更多)舞曲 ...

  9. BZOJ 3110 [Zjoi2013]K大数查询 ——整体二分

    [题目分析] 整体二分显而易见. 自己YY了一下用树状数组区间修改,区间查询的操作. 又因为一个字母调了一下午. 貌似树状数组并不需要清空,可以用一个指针来维护,可以少一个log 懒得写了. [代码] ...

随机推荐

  1. Serverless 如何在阿里巴巴实现规模化落地?

    作者 | 赵庆杰(卢令) 来源 | Serverless 公众号 一.Serverless 规模化落地集团的成果 2020 年,我们在 Serverless 底层基建上做了非常大的升级,比如计算升级到 ...

  2. java程序远程连接Linux服务器

    JSCH或 Ganymed Ganymed: Ganymed SSH-2 for Java是用纯Java实现SSH-2协议的一个包. 可以利用它直接在Java程序中连接SSH服务器.官网地址为 htt ...

  3. NX屏蔽窗口的按钮

    有时候在激活一个命令按钮的时候,需要同时禁止掉另外一个或多个命令按钮 ''' <summary> ''' 取按钮是否敏感 ''' </summary> ''' <para ...

  4. 网络通信IO的演变过程(二)(一个门外汉的理解)

    2.NIO 当与别人谈论NIO时,一定要弄清楚别人说的NIO是指哪个含义? NIO有2种含义: 1.NonBlocking IO,基于操作系统谈 2.Java New IO,基于Java谈 我们这里主 ...

  5. Unity——计时器功能实现

    Unity计时器 Demo展示 介绍 游戏中有非常多的计时功能,比如:各种cd,以及需要延时调用的方法: 一般实现有一下几种方式: 1.手动计时 float persistTime = 10f flo ...

  6. 测试小姐姐问我 gRPC 怎么用,我直接把这篇文章甩给了她

    原文链接: 测试小姐姐问我 gRPC 怎么用,我直接把这篇文章甩给了她 上篇文章 gRPC,爆赞 直接爆了,内容主要包括:简单的 gRPC 服务,流处理模式,验证器,Token 认证和证书认证. 在多 ...

  7. UltraSoft - Beta - Postmortem事后分析

    UltraSoft - Beta - PostMORTEM 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 解决的问题和定义都在[软软软]功能规格说明书 ...

  8. Beta阶段第三次会议

    Beta阶段第三次会议 完成工作 姓名 工作 难度 完成度 ltx 1.掌握小程序代码和相关知识2.构思小程序游客模式 轻 90% xyq 1.修改场地表格信息2.对原页面活动申请场地部分进行修改 轻 ...

  9. 计算机网络传输层之TCP协议(tcp协议特点、tcp报文段首部格式、tcp连接建立---三次握手、tcp连接释放---四次握手)

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/105516090 学习课程:<2019王道考研计算机网络> 学习目的 ...

  10. ASP.NET Core 学习笔记 第四篇 ASP.NET Core 中的配置

    前言 说道配置文件,基本大多数软件为了扩展性.灵活性都会涉及到配置文件,比如之前常见的app.config和web.config.然后再说.NET Core,很多都发生了变化.总体的来说技术在进步,新 ...