bzoj5358
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的更多相关文章
- [BZOJ5358]/[HDU6287]口算训练
[BZOJ5358]/[HDU6287]口算训练 题目大意: 给定一个长度为\(n(n\le10^5)\)的正整数序列\(a_{1\sim n}\),\(m(m\le10^5)\)次询问.每次询问给出 ...
- [Lydsy1805月赛]口算训练 BZOJ5358
分析: 没想到这道题还能二分查找... 这题主席树的话,裸的很显然...我们将每一个数分解质因数,之后建一个可持久化权值线段树维护[L,R]区间内的每一种质因子的个数,分解质因数的话,可以选择用线筛, ...
- [Bzoj5358][Lydsy1805月赛]口算训练(预处理+动态开点线段树)
5358: [Lydsy1805月赛]口算训练 Time Limit: 5 Sec Memory Limit: 512 MBSubmit: 318 Solved: 105[Submit][Stat ...
随机推荐
- Java多线程(一)多线程基础
一.进程 进程是操作系统结构的基础:是一次程序的执行:是一个程序及其数据在处理机上顺序执行时所发生的活动.操作系统中,几乎所有运行中的任务对应一条进程(Process).一个程序进入内存运行,即变成一 ...
- face detection[SSH]
该文来自<SSH: Single Stage Headless Face Detector>,本文时间线2017年8月. 不同于face rcnn那种两阶段的方法,SSH和ssd一样是一阶 ...
- 【vue】iView-admin后台管理系统
1.目录手册解析 2.跨域解决(axios访问服务器由于前端地址和后端地址不同源会出现跨域问题) 实例2 3.动态菜单导航+权限 4.webstorm 配置 Eslint 代码检查和自动修复
- redis底层设计(三)——redis数据类型
今天我们来看一下redis的数据类型.既然redis的键值对可以保存不同类型的值,那么很自然就需要对键值对的类型进行检查以及多态处理.下面我们将对redis所使用的对象系统进行了解,并分别观察字符串. ...
- FineUIMvc v1.4.0 发布了(ASP.NET MVC控件库)!
FineUIMvc v1.4.0 已经于 2017-06-30 发布,FineUIMvc 是基于 jQuery 的专业 ASP.NET MVC 控件库,是我们的新产品.由于和 FineUI(专业版)共 ...
- Spring Boot 2.0(八):Spring Boot 集成 Memcached
Memcached 介绍 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站 ...
- easyui datagrid 相关取数据总结
easyui 中datagrid$('#dg').datagrid('getSelected');返回第一个被选中的行或如果没有选中的行则返回null.$('#dg').datagrid('getSe ...
- 基于 Django的Ajax实现 文件上传
---------------------------------------------------------------遇到困难的时候,勇敢一点,找同学朋友帮忙,找导师求助. Ajax Ajax ...
- codeforces#1097 D. Makoto and a Blackboard(dp+期望)
题意:现在有一个数写在黑板上,它以等概率转化为它的一个约数,可以是1,问经过k次转化后这个数的期望值 题解:如果这个数是一个素数的n次方,那么显然可以用动态规划来求这个数的答案,否则的话,就对每个素因 ...
- Individual Project "写一个能自动生成小学四则运算题目的程序"
一.题目简介 写一个能自动生成小学四则运算题目的程序. 初步拟定要实现的功能后,估计一下自己需要花多长时间.编程过程中记录自己实际用了多长时间. 然后和同学们比较一下各自程序的功能.实现方法的异同等等 ...