[hdu7000]二分
不妨假设$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]二分的更多相关文章
- BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]
1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 8748 Solved: 3835[Submi ...
- BZOJ 2756: [SCOI2012]奇怪的游戏 [最大流 二分]
2756: [SCOI2012]奇怪的游戏 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 3352 Solved: 919[Submit][Stat ...
- 整体二分QAQ
POJ 2104 K-th Number 时空隧道 题意: 给出一个序列,每次查询区间第k小 分析: 整体二分入门题? 代码: #include<algorithm> #include&l ...
- [bzoj2653][middle] (二分 + 主席树)
Description 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整. 给你一个长度为n的序列s. 回答Q个这样的询问:s的左端点在[a,b ...
- [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 ...
- [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 ...
- jvascript 顺序查找和二分查找法
第一种:顺序查找法 中心思想:和数组中的值逐个比对! /* * 参数说明: * array:传入数组 * findVal:传入需要查找的数 */ function Orderseach(array,f ...
- BZOJ 1305: [CQOI2009]dance跳舞 二分+最大流
1305: [CQOI2009]dance跳舞 Description 一次舞会有n个男孩和n个女孩.每首曲子开始时,所有男孩和女孩恰好配成n对跳交谊舞.每个男孩都不会和同一个女孩跳两首(或更多)舞曲 ...
- BZOJ 3110 [Zjoi2013]K大数查询 ——整体二分
[题目分析] 整体二分显而易见. 自己YY了一下用树状数组区间修改,区间查询的操作. 又因为一个字母调了一下午. 貌似树状数组并不需要清空,可以用一个指针来维护,可以少一个log 懒得写了. [代码] ...
随机推荐
- Java基础- 重写,重构和重载
重写也称为覆盖, 是指子类与父类的方法名相同但是可以有不同的权限(子类权限需大于父类),返回值(J2SE 5.0以后增加的功能,且子类的返回值必须是父类返回值的子类)或者方法实现. 重写体现了子类补充 ...
- 9.亿级流量电商系统JVM模型参数预估方案
1. 需求分析 大促在即,拥有亿级流量的电商平台开发了一个订单系统,我们应该如何来预估其并发量?如何根据并发量来合理配置JVM参数呢? 假设,现在有一个场景,一个电商平台,比如京东,需要承担每天上亿的 ...
- bzoj1503 郁闷的出纳员(平衡树,思维)
题目大意: 现在有n个操作和一个最低限度m \(I\)命令\(I\ k\)新建一个工资档案,初始工资为k. \(A\)命令$A\ k $把每位员工的工资加上k \(S\)命令$S\ k $把每位员工的 ...
- docker中Jenkins启动无法安装插件,版本过低
一.问题现象: 使用docker启动jenkins,在jenkins启动后却无法安装jenkins的插件,一直提示安装失败且从log看到提示信息显示为需要升级jenkins的版本 二.原因分析: 在使 ...
- vue3 element-plus 配置json快速生成form表单组件,提升生产力近600%(已在公司使用,持续优化中)
️本文为博客园社区首发文章,未获授权禁止转载 大家好,我是aehyok,一个住在深圳城市的佛系码农♀️,如果你喜欢我的文章,可以通过点赞帮我聚集灵力️. 个人github仓库地址: https:gi ...
- Go语言核心36讲(Go语言进阶技术五)--学习笔记
11 | 通道的高级玩法 我们已经讨论过了通道的基本操作以及背后的规则.今天,我再来讲讲通道的高级玩法. 首先来说说单向通道.我们在说"通道"的时候指的都是双向通道,即:既可以发也 ...
- 测试小姐姐问我 gRPC 怎么用,我直接把这篇文章甩给了她
原文链接: 测试小姐姐问我 gRPC 怎么用,我直接把这篇文章甩给了她 上篇文章 gRPC,爆赞 直接爆了,内容主要包括:简单的 gRPC 服务,流处理模式,验证器,Token 认证和证书认证. 在多 ...
- BUAA软件工程个人博客作业
软件工程个人博客作业 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 个人博客作业 我在这个课程的目标 团队完成好的软件,并对自己作出规划 这个作 ...
- 使用logstash的input file filter收集日志文件
使用logstash的input file filter收集日志文件 一.需求 二.实现步骤 1.前置知识 2.编写pipeline文件 3.Input 中 file 插件的部分参数解释: 4.启动l ...
- spring cloud config 结合 spring cloud bus实现配置自定的刷新
在线上环境中,有时候我们希望系统中的某些配置参数在修改后,可以立即生效而不用重新启动服务.由上一节我们知道,我们可以把配置文件统一放到配置服务中进行管理,这一节我们在配置中心中整合spring clo ...