【AT987】高橋君
成爷爷一眼秒,\(tql!!!\)
多组询问,求
\]
发现\(k<=n\)啊,于是我们可以把一组询问抽象成一个区间\([k,n]\)
左指针的移动非常好解决,就是加一下\(C_n^k\)减一下\(C_n^k\)就好了
考虑一下右指针的移动,就是\(n+1\)或者\(n-1\)
如果\(n+1\),就是从\(\sum_{i=0}^kC_n^i\)变成了\(\sum_{i=0}^kC_{n+1}^i\)
我们利用组合数的小学生求法,拆开我们的柿子
\]
如果是\(n-1\),就是求
\]
也就是
\]
发现我们要求的东西都能从\(\sum_{i=0}^kC_n^i\)在\(O(1)\)推过去
于是莫队就没了
成爷爷奇偶性排序\(wa\)了,这告诉我们拒绝玄学
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define re register
#define LL long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
const int maxn=1e5+5;
inline int read() {
char c=getchar();int x=0;while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9') x=(x<<3)+(x<<1)+c-48,c=getchar();return x;
}
const LL mod=1e9+7;
struct Ask{
int l,r,rk;
}q[maxn];
LL fac[maxn],inv[maxn],I2,ans;
int Ans[maxn];
int n,m,sz,L,R;
inline int cmp(Ask A,Ask B) {
if(A.l/sz==B.l/sz) return A.r<B.r;
return A.l<B.l;
}
inline LL ksm(LL a,int b) {
LL S=1;
while(b) {if(b&1) S=S*a%mod;b>>=1;a=a*a%mod;}
return S;
}
inline LL C(int n,int m) {
if(n<m) return 0;
return fac[n]*inv[n-m]%mod*inv[m]%mod;
}
inline void add_(int x) {ans+=C(R,x);ans%=mod;}
inline void del_(int x) {ans-=C(R,x);ans=(ans+mod)%mod;}
inline void add(int x) {
ans=(ans*2ll)%mod;
ans=(ans-C(x-1,L)+mod)%mod;
}
inline void del(int x) {
ans=(ans+C(x-1,L))%mod;
ans=(ans*I2)%mod;
}
int main() {
m=read();
for(re int i=1;i<=m;i++)
q[i].r=read(),q[i].l=read(),q[i].rk=i,n=max(n,q[i].r);
fac[0]=1;
for(re int i=1;i<=n;i++)
fac[i]=(fac[i-1]*(LL)i)%mod;
inv[n]=ksm(fac[n],mod-2);
for(re int i=n-1;i>=0;--i)
inv[i]=(inv[i+1]*(LL)(i+1))%mod;
sz=std::sqrt(n);
I2=ksm(2ll,mod-2);
L=1,R=1;ans=2;
std::sort(q+1,q+m+1,cmp);
for(re int i=1;i<=m;i++) {
while(R<q[i].r) add(++R);
while(L>q[i].l) del_(L--);
while(L<q[i].l) add_(++L);
while(R>q[i].r) del(R--);
Ans[q[i].rk]=ans;
}
for(re int i=1;i<=m;i++) printf("%d\n",Ans[i]);
return 0;
}
【AT987】高橋君的更多相关文章
- AT987 高橋君
AT987 高橋君 给出 \(n,\ k\) ,求 \(\displaystyle\sum_{i=0}^kC_n^k\) , \(T\) 次询问 \(T\leq10^5,\ 0\leq k\leq n ...
- 高橋君とホテル / Tak and Hotels
高橋君とホテル / Tak and Hotels Time limit : 3sec / Stack limit : 256MB / Memory limit : 256MB Score : 700 ...
- 高橋君とカード / Tak and Cards
高橋君とカード / Tak and Cards Time limit : 2sec / Stack limit : 256MB / Memory limit : 256MB Score : 300 p ...
- 高橋君とカード / Tak and Cards AtCoder - 2037 (DP)
Problem Statement Tak has N cards. On the i-th (1≤i≤N) card is written an integer xi. He is selectin ...
- AtCoder Beginner Contest 044 C - 高橋君とカード / Tak and Cards
题目链接:http://abc044.contest.atcoder.jp/tasks/arc060_a Time limit : 2sec / Memory limit : 256MB Score ...
- AtCoder Beginner Contest 044 A - 高橋君とホテルイージー / Tak and Hotels (ABC Edit)
Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement There is a hotel with ...
- AtCoder D - 高橋君と見えざる手 / An Invisible Hand 简单思维题
http://arc063.contest.atcoder.jp/tasks/arc063_b 因为每次都是选取最大值,那么用dp[i]表示第i个数结尾能得到最大是多少. 其实就是用a[i]去减去左边 ...
- AtCoder Beginner Contest 022 A.Best Body 水题
Best Body Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://abc022.contest.atcoder.jp/tasks/abc02 ...
- AtCoder-arc060 (题解)
A - 高橋君とカード / Tak and Cards (DP) 题目链接 题目大意: 有 \(n\) 个数字,要求取出一些数字,使得它们的平均数恰好为 \(x\) ,问有几种取法. 大致思路: 只要 ...
随机推荐
- HNCU专题训练_线段树(2)
1.统计颜色,或运算的运用2.区间第k大数3.一个很经典的题5.求区间相等数字的个数6.RMQ模板题,区间最大值和最小值的差 1.很好的思路,用或运算来避免左右儿子树总相同颜色的情况.由于T颜色种类最 ...
- 记一次简单爬虫(豆瓣/dytt)
磕磕绊绊学python一个月,这次到正则表达式终于能写点有趣的东西,在此作个记录: ————————————————————————————————————————————————— 1.爬取豆瓣电影 ...
- angular2 引入jquery
(注:以下命令都是在项目文件夹根目录下运行的,保证下载的文件都在项目的node_modules文件夹里面) 1. 运行 npm install jquery -save 后会发现在package.j ...
- pom.xml 如果使用 mvn exec:exec 命令运行项目
pom.xml 如果使用 mvn exec:exec 命令运行项目,红色字体要与groupid相同 <project xmlns="http://maven.apache.org/PO ...
- 移动端meta标签设置
移动端meta标签设置 1.设置当前html文件的字符编码 <meta charset="UTF-8"> 1 2设置浏览器的兼容模式(让IE使用最新的浏览器渲染) &l ...
- 热血沙城-3.2移植-古月-cocos2dx源码
最近发现我去年学习2dx的时候移植过的一个游戏现在被放在网上出售 真是有点想笑 本人比较喜欢武侠风格的游戏,当时9秒开源了热血沙城 本着学习的态度 从2.1.2移植到3.2 用了一周的时间 中间各种 ...
- Android 图板之保存图像
(1)为了能适应多种屏幕尺寸的手机,我们在创建图像的时候就要根据用户手机屏幕的宽高像素来创建. (2)该软件将把图形保存到sdcard中,在保存之前,需要检测sdcard是否存在,是否可写入.如通过以 ...
- Pig模式
Pig中的模式可以是用户显示声明的,也可以是Pig通过用户的使用方式猜测的. Pig对模式的认知在Pig Latin脚本执行的不同阶段可能是不同的. 下面的语句,用户显示声明了模式:3个字段, ...
- redis介绍(3)RDB和AOF原理解析
简单科普一下redis的概念:(会的可忽略) Redis的概念 redis基于内存的Key Value类型的NoSQL数据库. Redis的特点 1. Redis是一个高性能的Key/Value数据库 ...
- linux安装memcached
一:为什么要使用memcached 瓶颈:互联网发展,特别在web2.0兴起之后,传统数据库开始出现瓶颈 1:对数据库的高并发读写 2:对海量数据库的处理(海量数据查找)memcache 是高性能的分 ...