Problem A. 口算训练
Input file: stdin
Output file: stdout
Time limit: 5 seconds
Memory limit: 512 megabytes
小 Q 非常喜欢数学,但是他的口算能力非常弱。因此他找到了小 T,给了小 T 一个长度为 n 的正
整数序列 a1, a2, ..., an,要求小 T 抛出 m 个问题以训练他的口算能力。
每个问题给出三个正整数 l, r, d,小 Q 需要通过口算快速判断 al × al+1 × ... × ar−1 × ar 是不是 d
的倍数。
小 Q 迅速地回答了出来,但是小 T 并不知道正确答案是什么,请写一个程序帮助小 T 计算这些问
题的正确答案。
Input
第一行包含一个正整数 T(1 ≤ T ≤ 10),表示测试数据的组数。
每组数据第一行包含两个正整数 n, m(1 ≤ n, m ≤ 100000),分别表示序列长度以及问题个数。
第二行包含 n 个正整数 a1, a2, ..., an(1 ≤ ai ≤ 100000),表示序列中的每个数。
接下来 m 行,每行三个正整数 l, r, d(1 ≤ l ≤ r ≤ n, 1 ≤ d ≤ 100000),表示每个问题。
Output
对于每个问题输出一行,若是倍数,输出“Yes”,否则输出“No”。
Examples
stdin

1
5 4
6 4 7 2 5
1 2 24
1 3 18
2 5 17
3 5 35

stdout
Yes
No
No
Yes

sol:这题数据 ai 很小,所以XJB搞搞就能过,就把<=sqrtai的ai的质因数筛出来,然后记个数组,对于>=sqrtai的约数肯定只有一个,所以开个vector特判一下就能过了

#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=;
bool f=;
char ch=' ';
while(!isdigit(ch))
{
f|=(ch=='-'); ch=getchar();
}
while(isdigit(ch))
{
s=(s<<)+(s<<)+(ch^); ch=getchar();
}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<)
{
putchar('-'); x=-x;
}
if(x<)
{
putchar(x+''); return;
}
write(x/);
putchar((x%)+'');
return;
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
const int N=,B=;
int n,m;
int Prim[N];
bool Bo[N];
int S[N][B];
vector<int>Pos[N];
inline void Shai(int Up)
{
int i,j;
Bo[]=Bo[]=;
for(i=;i<=Up;i++)
{
if(!Bo[i]) Prim[++*Prim]=i;
for(j=;j<=*Prim&&(Prim[j]*i<=Up);j++)
{
Bo[Prim[j]*i]=;
if(i%Prim[j]==) break;
}
}
return;
}
int main()
{
int i,j;
Shai();
R(n); R(m);
for(i=;i<=n;i++)
{
int x=read();
for(j=;j<=*Prim;j++)
{
S[i][j]=S[i-][j];
if(x%Prim[j]==)
{
while(x%Prim[j]==)
{
S[i][j]++; x/=Prim[j];
}
}
}
if(x>) Pos[x].push_back(i);
}
while(m--)
{
int l=read(),r=read(),x=read();
bool Bo=;
for(j=;j<=*Prim;j++) if(x%Prim[j]==)
{
int oo=;
while(x%Prim[j]==)
{
oo++; x/=Prim[j];
}
if(S[r][j]-S[l-][j]<oo)
{
Bo=; break;
}
}
if(x>)
{
vector<int>::iterator it=lower_bound(Pos[x].begin(),Pos[x].end(),l);
int Wz;
if(it!=Pos[x].end()) Wz=(*it);
else Wz=n+;
if(Wz>r) Bo=;
}
(Bo)?(puts("No")):puts("Yes");
}
return ;
}
/*
input
5 4
6 4 7 2 5
1 2 24
1 3 18
2 5 17
3 5 35
output
Yes
No
No
Yes input
5 1
2087 2 2 2 2
1 2 4174
output
Yes
*/

bzoj5358的更多相关文章

  1. [BZOJ5358]/[HDU6287]口算训练

    [BZOJ5358]/[HDU6287]口算训练 题目大意: 给定一个长度为\(n(n\le10^5)\)的正整数序列\(a_{1\sim n}\),\(m(m\le10^5)\)次询问.每次询问给出 ...

  2. [Lydsy1805月赛]口算训练 BZOJ5358

    分析: 没想到这道题还能二分查找... 这题主席树的话,裸的很显然...我们将每一个数分解质因数,之后建一个可持久化权值线段树维护[L,R]区间内的每一种质因子的个数,分解质因数的话,可以选择用线筛, ...

  3. [Bzoj5358][Lydsy1805月赛]口算训练(预处理+动态开点线段树)

    5358: [Lydsy1805月赛]口算训练 Time Limit: 5 Sec  Memory Limit: 512 MBSubmit: 318  Solved: 105[Submit][Stat ...

随机推荐

  1. C#使用Json.Net遍历Json

    StringBuilder builder=new StringBuilder(); builder.AppendLine("{"); builder.AppendLine(&qu ...

  2. docker部署nginx

    1. 下载nginx [root@localhost my.Shells]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE docker.io/ ...

  3. 【教程】switch上的Human Fall Flat如何设置本地双人?

    1. 保证两个手柄已插入主机上 2. 进入游戏至游戏开始界面 3. 将主机插入拓展坞,等待电视显示 4. 稍等数秒,电视上会提示使用手柄方式 5. 此时按照多人游戏的手柄操作方法即可

  4. CSS Modules入门教程

    为什么引入CSS Modules 或者可以这么说,CSS Modules为我们解决了什么痛点.针对以往我写网页样式的经验,具体来说可以归纳为以下几点: 全局样式冲突 过程是这样的:你现在有两个模块,分 ...

  5. Python_每日习题_0007_copy

    题目:将一个列表的数据复制到另一个列表中. 程序分析:使用列表[:],拿不准可以调用copy模块 import copy a = [,,,,['a','b']] b = a #赋值 c = a[:] ...

  6. [2018福大至诚软工助教]alpha阶段小结

    [2018福大至诚软工助教]alpha阶段小结 一.得分 1. 冲刺(7次 Scrum) 150分 1)第1篇(25分) 项目 评分标准 各个成员在 Alpha 阶段认领的任务 (6分)视详细程度给分 ...

  7. 多线程系列之十一:Two-Phase Termination模式

    一,Two-Phase Termination模式 翻译过来就是:分两阶段终止 二,示例程序 public class CountupTread extends Thread { private lo ...

  8. 【kindle笔记】之 《鬼吹灯》-9-20

    [kindle笔记]读书记录-总 9-20 日常吐槽 连着几天,基本是一口气读完了鬼吹灯. 想来,也算是阴差阳错了.本来是想看盗墓的,读了几页开头,心想坏了,拷贝错了,这是鬼吹灯-- 讲真的,每每读小 ...

  9. VMware虚拟机与Windows文件共享

    开发中,我们经常的需求是这样的:我想再Windows中进行快捷开发,但是想在linux中运行,那么需要将文件方便在linux中管理,基本可以分成两种方式: 1. 使用网络工具:vmware_tool工 ...

  10. C#复习笔记(3)--C#2:解决C#1的问题(实现迭代器的捷径)

    实现迭代器的捷径 从这个题目上可以看到C#1实现一个迭代器模式的话是多么的痛苦,我自己也写过不下40行的代码来实现一个迭代器,C#中的迭代器模式是通过IEnumerable和他的泛型等价物IEnume ...