【JZOJ4792】【NOIP2016提高A组模拟9.21】整除
题目描述
麦克雷有一个1~n的排列,他想知道对于一些区间,有多少对区间内的数(x,y),满足x能被y整除。
输入
第一行包含2个正整数n,m。表示有n个数,m个询问。
接下来一行包含n个正整数,表示麦克雷有的数列。
接下来m行每行包含2个正整数l,r。表示询问区间[l,r]。
输出
共 m 行,每行一个整数,表示满足条件的对数。
样例输入
10 9
1 2 3 4 5 6 7 8 9 10
1 10
2 9
3 8
4 7
5 6
2 2
9 10
5 10
4 10
样例输出
27
14
8
4
2
1
2
7
9
数据范围
30%:1<=n,m<=100
100%:1<=n,m<=2*10^5,1<=pi<=n
解法
对于一个区间[l,r],它的答案=区间[1,r]中的总贡献-区间[1,r]中[1,l-1]的贡献。
证明:
显然,区间[l,r]的答案=区间[1,r]的答案-区间[1,l]的答案-所有(a[i],a[j])的贡献。(其中i∈[1,l],j∈[1,r])
而又,区间[1,l]的答案+所有(a[i],a[j])的贡献=区间[1,r]中[1,l-1]的贡献;
所以区间[l,r]的答案=区间[1,r]中的总贡献-区间[1,r]中[1,l-1]的贡献。
如果把区间按右端点升序排序,那么使用扫描线即可将问题转化为:
区间[1,r]中,任意区间贡献和。
用树状数组维护即可。
代码
#include<iostream>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#define ll long long
#define ln(x,y) ll(log(x)/log(y))
#define sqr(x) ((x)*(x))
using namespace std;
const char* fin="aP3.in";
const char* fout="aP3.out";
const ll inf=0x7fffffff;
const ll maxn=200007,maxt=maxn*5;
ll n,m,i,j,k,l,r,ks,cnt;
ll tmp=0;
ll a[maxn],b[maxn],c[maxn];
ll ans[maxn];
ll hh[maxn];
bool bz[maxn];
struct q{
ll l,r,id;
}qu[maxn];
bool cmp(q a,q b){
return a.r<b.r;
}
void change(ll v,ll v1){
if (!bz[v]) return;
v=b[v];
cnt+=v1;
for (;v<=n;v+=v&-v) c[v]+=v1;
}
ll getsum(ll v){
ll x=0;
for (;v;v-=v&-v) x+=c[v];
return x;
}
ll getsum(ll l,ll r){
return getsum(r)-getsum(l-1);
}
void join(ll v){
ll i,j,k;
bz[a[v]]=true;
for (i=1;i<=(ll)(sqrt(a[v]));i++){
if (a[v]%i==0){
change(a[v]/i,1);
if (i*i!=a[v]) change(i,1);
}
}
for (i=a[v]*2;i<=n;i+=a[v]) change(i,1);
}
int main(){
scanf("%d%d",&n,&m);
ks=sqrt(n);
for (i=1;i<=n;i++){
scanf("%d",&a[i]);
b[a[i]]=i;
}
for (i=1;i<=m;i++){
scanf("%d%d",&qu[i].l,&qu[i].r);
qu[i].id=i;
}
sort(qu+1,qu+m+1,cmp);
r=0;
for (i=1;i<=m;i++){
while (r<qu[i].r) {
join(++r);
}
ans[qu[i].id]=cnt-getsum(qu[i].l-1);
}
for (i=1;i<=m;i++) printf("%lld\n",ans[i]);
return 0;
}
启发
离线的区间问题归结为:
莫队算法
范围
对于已知区间,给其加入元素或删除元素以较低复杂度完成。
则适用莫队算法。
扩展
如果加入元素简单,删除元素难,那么就可以使用只增莫队算法。
参考这一题。
分块
坑待填
区间拆分扫描线
范围
当[1,i]容易计算时,且区间[l,r]可拆分成[1,r]和[1,l-1];
则适用区间拆分扫描线。
参考这一题。
扩展
如果[l,r]拆分后满足ans([l,r])=ans([1,r])-ans([1,l-1])-ans(分属于[1,l-1],[l,r]);
那么是可以将ans([l,r])=ans([1,r])-[1,r]下[1,l-1]的贡献。
参考本题。
【JZOJ4792】【NOIP2016提高A组模拟9.21】整除的更多相关文章
- [jzoj 4722] [NOIP2016提高A组模拟8.21] 跳楼机 解题报告 (spfa+同余)
题目链接: http://172.16.0.132/senior/#main/show/4722 题目: DJL为了避免成为一只咸鱼,来找srwudi学习压代码的技巧.Srwudi的家是一幢h层的摩天 ...
- 【JZOJ4791】【NOIP2016提高A组模拟9.21】矩阵
题目描述 在麦克雷的面前出现了一个有n*m个格子的矩阵,每个格子用"."或"#"表示,"."表示这个格子可以放东西,"#" ...
- 【JZOJ4790】【NOIP2016提高A组模拟9.21】选数问题
题目描述 在麦克雷的面前有N个数,以及一个R*C的矩阵.现在他的任务是从N个数中取出R*C个,并填入这个矩阵中.矩阵每一行的法值为本行最大值与最小值的差,而整个矩阵的法值为每一行的法值的最大值.现在, ...
- JZOJ 4732. 【NOIP2016提高A组模拟8.23】函数
4732. [NOIP2016提高A组模拟8.23]函数 (Standard IO) Time Limits: 1500 ms Memory Limits: 262144 KB Detailed ...
- 【NOIP2016提高A组模拟9.14】数列编辑器
题目 分析 比赛上,没有注意到询问只询问光标前面,于是只打了个暴力. 因为询问只询问光标前面,首先,当光标向后每移动到一个位置,顺便将这个位置的前缀和,和最大前缀和求出来. 总之,模拟 #includ ...
- 【NOIP2016提高A组模拟9.24】总结
第一题纯模拟,结果那个出题人脑子似乎进水了,空间限制开了1G!!! 导致我捉摸了半天为什么空间要开那么大,最后只能得出上面的结论. 第二题是个矩阵快速幂,比赛上我没把递推式求出来,但是根据各种乱搞,得 ...
- 【JZOJ4711】【NOIP2016提高A组模拟8.17】Binary
题目描述 输入 输出 样例输入 6 6 8 9 1 13 9 3 1 4 5 2 6 9 1 3 7 2 7 7 1 6 1 2 11 13 样例输出 45 19 21 数据范围 解法 40%暴力即可 ...
- 【JZOJ4747】【NOIP2016提高A组模拟9.3】被粉碎的线段树
题目描述 输入 第一行包括两个正整数,N ,M ,分别表示线段树的宽以及询问次数. 以下N-1 行以先序遍历(dfs深搜顺序)描述一个小R线段树,每行一个正整数表示当前非叶子节点的 mid,保证每个节 ...
- 【JZOJ4746】【NOIP2016提高A组模拟9.3】树塔狂想曲
题目描述 相信大家都在长训班学过树塔问题,题目很简单求最大化一个三角形数塔从上往下走的路径和.走的规则是:(i,j)号点只能走向(i+1,j)或者(i+1,j+1).如下图是一个数塔,映射到该数塔上行 ...
随机推荐
- 微信小程序slider应用,可加减的slider控制
<view class="control-w "> <block wx:for="{{controls}}" wx:key="id& ...
- 你所不知道的Mac截图的强大
Mac的截图功能扩展功能很强大的,不要用QQ那个COM+Ctrl+A弱爆了的截图了~ 首先说一下两种截图 1.Command+shift+3:全屏截图,保存截图到桌面 2.Command+shift+ ...
- DSMM之数据处理安全
一.背景 数据安全生命周期分为采集.传输.存储.处理.交换.销毁几个阶段,其中数据处理阶段是整个周期的核心阶段,数据处理安全与否直接关系到整体数据安全.那么今天分享内容就是数据处理安全的相关要求和实现 ...
- Maven实战01_Maven简介
1:何为Maven Maven:中文翻译为"知识的积累",也可翻译为"专家"或"内行". 谈到Maven,就不得不提"构建(bui ...
- Spring Cloud Security&Eureka安全认证(Greenwich版本)
Spring Cloud Security&Eureka安全认证(Greenwich版本) 一·安全 Spring Cloud支持多种安全认证方式,比如OAuth等.而默认是可以直接添加spr ...
- CImage 是基于GDI+的,很老的一篇文章,我很久很久以前看到过的
在许多资料上都说CImage类是基于GDI+的,但是为什么是基于GDI+的呢? 因为使用这个类时,并没有加入#include <gdiplus.h> ,也没有在程序开始和结束时分别写GDI ...
- tensorflow/model下的各个参数的理解
首先,这个对应的proto就是 然后config里面的image_resizer等等 就是proto里面的image_resizer 等等,对应的参数可以在proto里面寻找解释和默认值以及类型 再比 ...
- pytorch 多GPU训练过程中出现ap=0情况
原因可能是pytorch 自带的BN bug:安装nvidia apex 可以解决: $ git clone https://github.com/NVIDIA/apex $ cd apex $ pi ...
- 全景还原报错现场 | 应用实时监控 ARMS 上线用户行为回溯功能
随着前端技术日新月异迅猛发展,为了实现更好的前端性能,最大程度提高用户体验,支持单页应用的框架逐渐占领市场,如众所周知的React,Vue等等.但是在单页应用的趋势下,快速定位并解决JS错误却成为一大 ...
- 移动端H5适配流程
(一) 由于手机生产商越来越多,不同手机的硬件尺寸又不尽相同,这就给我们的设计适配造成很大困扰.但我们可以围绕从基准分辨率设计,上下进行兼容适配的原则来进行快捷操作.以IOS阵营为例: 图注:移动适配 ...