当前位置:网站首页>Codeforces 474 F. Ant colony
Codeforces 474 F. Ant colony
2022-07-07 20:47:00 【Full stack programmer webmaster】
Hello everyone , I meet you again , I'm the king of the whole stack .
The line segment tree seeks the GCD…..
F. Ant colony
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Mole is hungry again. He found one ant colony, consisting of n ants, ordered in a row. Each ant i (1 ≤ i ≤ n) has a strength si.
In order to make his dinner more interesting, Mole organizes a version of «Hunger Games» for the ants. He chooses two numbers l and r(1 ≤ l ≤ r ≤ n) and each pair of ants with indices between l and r (inclusively) will fight. When two ants i and j fight, ant i gets one battle point only if si divides sj (also, ant j gets one battle point only if sj divides si).
After all fights have been finished, Mole makes the ranking. An ant i, with vi battle points obtained, is going to be freed only if vi = r - l, or in other words only if it took a point in every fight it participated. After that, Mole eats the rest of the ants. Note that there can be many ants freed or even none.
In order to choose the best sequence, Mole gives you t segments [li, ri] and asks for each of them how many ants is he going to eat if those ants fight.
Input
The first line contains one integer n (1 ≤ n ≤ 105), the size of the ant colony.
The second line contains n integers s1, s2, …, sn (1 ≤ si ≤ 109), the strengths of the ants.
The third line contains one integer t (1 ≤ t ≤ 105), the number of test cases.
Each of the next t lines contains two integers li and ri (1 ≤ li ≤ ri ≤ n), describing one query.
Output
Print to the standard output t lines. The i-th line contains number of ants that Mole eats from the segment [li, ri].
Sample test(s)
input
5
1 3 2 4 2
4
1 5
2 5
3 5
4 5
output
4
4
1
1
Note
In the first test battle points for each ant are v = [4, 0, 2, 0, 2], so ant number 1 is freed. Mole eats the ants 2, 3, 4, 5.
In the second test case battle points are v = [0, 2, 0, 2], so no ant is freed and all of them are eaten by Mole.
In the third test case battle points are v = [2, 0, 2], so ants number 3 and 5 are freed. Mole eats only the ant 4.
In the fourth test case battle points are v = [0, 1], so ant number 5 is freed. Mole eats the ant 4.
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <map>
#include <vector>
using namespace std;
const int maxn=100100;
typedef pair<int,int> pII;
pII b[maxn];
int n,s[maxn];
int g[maxn<<2];
int gcd(int x,int y)
{
if(x==0) return y;
return gcd(y%x,x);
}
void build(int l,int r,int rt)
{
if(l==r)
{
g[rt]=s[l];
return ;
}
int mid=(l+r)/2;
build(l,mid,rt<<1); build(mid+1,r,rt<<1|1);
g[rt]=gcd(g[rt<<1],g[rt<<1|1]);
}
int query(int L,int R,int l,int r,int rt)
{
if(r<L||l>R) return 0;
if(L<=l&&r<=R)
{
return g[rt];
}
int mid=(l+r)/2;
int u=query(L,R,l,mid,rt<<1);
int v=query(L,R,mid+1,r,rt<<1|1);
return gcd(u,v);
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",s+i);
b[i]=(make_pair(s[i],i));
}
sort(b+1,b+1+n);
build(1,n,1);
int m;
scanf("%d",&m);
while(m--)
{
int Left,Right;
scanf("%d%d",&Left,&Right);
int G=query(Left,Right,1,n,1);
int from=lower_bound(b+1,b+n+1,make_pair(G,Left))-(b+1);
int to=lower_bound(b+1,b+1+n,make_pair(G,Right+1))-(b+1);
printf("%d\n",(Right-Left+1)-(to-from));
}
return 0;
}
Publisher : Full stack programmer stack length , Reprint please indicate the source :https://javaforall.cn/116374.html Link to the original text :https://javaforall.cn
边栏推荐
- Details of C language integer and floating-point data storage in memory (including details of original code, inverse code, complement, size end storage, etc.)
- 恶魔奶爸 B1 听力最后壁垒,一鼓作气突破
- CodeSonar通过创新型静态分析增强软件可靠性
- C language helps you understand pointers from multiple perspectives (1. Character pointers 2. Array pointers and pointer arrays, array parameter passing and pointer parameter passing 3. Function point
- 95年专注安全这一件事 沃尔沃未来聚焦智能驾驶与电气化领域安全
- Flask1.1.4 werkzeug1.0.1 source code analysis: Routing
- Small guide for rapid formation of manipulator (11): standard nomenclature of coordinate system
- POJ 1742 coins (monotone queue solution) [suggestions collection]
- 复杂因子计算优化案例:深度不平衡、买卖压力指标、波动率计算
- Tensorflow2.x下如何运行1.x的代码
猜你喜欢
Dachang classic pointer written test questions
测量楼的高度
AADL Inspector 故障树安全分析模块
Ubuntu安装mysql8遇到的问题以及详细安装过程
Implement secondary index with Gaussian redis
CodeSonar网络研讨会
万字总结数据存储,三大知识点
Onespin | solve the problems of hardware Trojan horse and security trust in IC Design
使用高斯Redis实现二级索引
OneSpin | 解决IC设计中的硬件木马和安全信任问题
随机推荐
OneSpin 360 DV新版发布,刷新FPGA形式化验证功能体验
Validutil, "Rethinking the setting of semi supervised learning on graphs"
HDU4876ZCC loves cards(多校题)
恶魔奶爸 指南帖——简易版
guava多线程,futurecallback线程调用不平均
开发一个小程序商城需要多少钱?
Postgresql数据库character varying和character的区别说明
国家正规的股票交易app有哪些?使用安不安全
Codesonar enhances software reliability through innovative static analysis
Codeforces Round #296 (Div. 2) A. Playing with Paper[通俗易懂]
恶魔奶爸 A3阶段 近常速语流初接触
Numerical method for solving optimal control problem (0) -- Definition
让这个CRMEB单商户微信商城系统火起来,太好用了!
Codeforces 474 F. Ant colony
Update iteration summary of target detection based on deep learning (continuous update ing)
论文解读(ValidUtil)《Rethinking the Setting of Semi-supervised Learning on Graphs》
Cantata9.0 | new features
awk处理JSON处理
AADL Inspector 故障树安全分析模块
openGl超级宝典学习笔记 (1)第一个三角形「建议收藏」