中文题面:

问题描述】
我们定义一个非负整数是“好数”,当且仅当它符合以下条件之一:
1. 这个数是0或1
2. 所有小于这个数且与它互质的正整数可以排成一个等差数列
例如,8就是一个好数,因为1,3,5,7排成了等差数列。
给出N个非负整数,然后进行如下三个操作:
1. 询问区间[L,R]有多少个好数
2. 将区间[L,R]内所有数对S取余(S≤1000000)
3. 将第C个数更改为X
提示:如果你不知道如何判断一个数是否为好数,你可以打个表找找规律。
【输入格式】
输入文件名为good.in。
第一行包含两个正整数N和M,M表示操作数目
第二行包含N个非负整数。
接下来的M行每行表示1个操作:“1 L R”表示第1个操作,“2 L R S”表
示第2个操作,“3 C X”表示第3个操作。
【输出格式】
输出文件名为color.out。
对每个操作1,输出一个非负整数,表示区间内好数的个数。
【输入输出样例1】 
3 6
4 6 9
1 1 3
1 3 3
2 1 1 10
1 1 3
3 2 4
1 1 3

输出
2

0

2

2

数据规模与约定】
样例点编号 N M N个数大小(≤) 具有的操作
1,2 100 100 100 1,2,3
3,4 1000 1000 1000000 1,2,3
5,6,7 100000 100000 1000000 1,3
8,9,10 100000 100000 1000000 1,2,3

题解:

这个题目首先要打表找到好数的规律,不难发现只有2幂,质数以及6是好数,那么这个题目就可以预处理出1~100000中的所有的好数,用线性筛就可以了,知道这个东西之后题目就变成了统计区间好数的个数,用线段树维护就可以了,但这个题目要区间取模,因为对于一个数最多只要取模logn次就可以取模完成,所以只要在线段树中每次递归到叶子节点,暴力取就可以了,(当然模数>区间最大值时就不要模了)。

代码:(没写多组数据的,改一下就好了)

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <iostream>
#define MAXN 1000015
#define MAXN2 100015
using namespace std;
struct tree{
int l,r,x,shu,maxx;
}a[MAXN2*];
bool can[MAXN];
int zhi[MAXN2];
int n,m; void yvchuli(){
memset(can,,sizeof(can));
can[]=can[]=;
for(int i=;i<=;i++){
if(can[i]){
for(int j=i*;j<=;j+=i) can[j]=;
}
}
can[]=can[]=can[]=;
int now=;
while(now<=) {can[now]=;now*=;}
} void build(int xv,int l,int r){
if(l==r){
a[xv].l=l,a[xv].r=r;
a[xv].shu=zhi[l],a[xv].maxx=zhi[l];
if(can[zhi[l]]) a[xv].x=;
else a[xv].x=;
return;
}
a[xv].l=l,a[xv].r=r;
int mid=(l+r)/;
build(xv*,l,mid);build(xv*+,mid+,r);
a[xv].maxx=max(a[xv*].maxx,a[xv*+].maxx);
a[xv].x=a[xv*].x+a[xv*+].x;
} int query(int xv,int l,int r){
int L=a[xv].l,R=a[xv].r,mid=(L+R)/;
if(l==L&&r==R){
return a[xv].x;
}
if(r<=mid) return query(xv*,l,r);
if(l>mid) return query(xv*+,l,r);
return query(xv*,l,mid)+query(xv*+,mid+,r);
} void change(int xv,int pos,int hh){
int l=a[xv].l,r=a[xv].r,mid=(l+r)/;
if(l==r&&l==pos){
a[xv].shu=hh;
a[xv].maxx=hh;
if(can[hh]) a[xv].x=;
else a[xv].x=;
return;
}
if(pos<=mid) change(xv*,pos,hh);
else change(xv*+,pos,hh);
a[xv].x=a[xv*].x+a[xv*+].x;
a[xv].maxx=max(a[xv*].maxx,a[xv*+].maxx);
} void Ray(int xv,int l,int r,int S){
int L=a[xv].l,R=a[xv].r,mid=(L+R)/;
if(a[xv].maxx<S) return;
if(L==R){
a[xv].shu%=S;
a[xv].maxx=a[xv].shu;
if(can[a[xv].shu]) a[xv].x=;
else a[xv].x=;
return;
}
if(r<=mid) Ray(xv*,l,r,S);
else if(l>mid) Ray(xv*+,l,r,S);
else Ray(xv*,l,mid,S),Ray(xv*+,mid+,r,S);
a[xv].x=a[xv*].x+a[xv*+].x;
a[xv].maxx=max(a[xv*].maxx,a[xv*+].maxx);
} int main()
{
yvchuli();
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) scanf("%d",&zhi[i]);
build(,,n);
while(m--){
int id,x,y,z;scanf("%d%d%d",&id,&x,&y);
if(id==){
int numm=query(,x,y);
printf("%d\n",numm);
}
else if(id==){
scanf("%d",&z);
Ray(,x,y,z);
}
else change(,x,y);
}
return ;
}

zoj 3886 Nico Number的更多相关文章

  1. ZOJ 3886 Nico Number(筛素数+Love(线)Live(段)树)

    problemCode=3886">ZOJ 3886 题意: 定义一种NicoNico数x,x有下面特征: 全部不大于x且与x互质的数成等差数列,如x = 5 ,与5互素且不大于5的数 ...

  2. ZOJ 3622 Magic Number 打表找规律

    A - Magic Number Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Subm ...

  3. ZOJ 3436 July Number(DFS)

    题意   把一个数替换为这个数相邻数字差组成的数  知道这个数仅仅剩一位数  若最后的一位数是7  则称原来的数为 July Number  给你一个区间  求这个区间中July Number的个数 ...

  4. ZOJ 3233 Lucky Number

    Lucky Number Time Limit: 5000ms Memory Limit: 32768KB This problem will be judged on ZJU. Original I ...

  5. [ZOJ 3622] Magic Number

    Magic Number Time Limit: 2 Seconds      Memory Limit: 32768 KB A positive number y is called magic n ...

  6. ZOJ 3622 Magic Number(数)

    题意  假设一个正整数y满足  将随意正整数x放到y的左边得到的数z满足 z%y==0  那么这个数就是个Magic Number   给你一个范围  求这个范围内Magic Number的个数 令 ...

  7. zoj 1526 Big Number 数学

    Big Number Time Limit: 10 Seconds      Memory Limit: 32768 KB In many applications very large intege ...

  8. ZOJ 3690 Choosing number(矩阵)

    Choosing number [题目链接]Choosing number [题目类型]矩阵 &题解: 这题就和已经dp极像了,所以找方程就很困难了.可以这样找: 设f(n)是前n-1个人已经 ...

  9. ZOJ 3702 Gibonacci number 2017-04-06 23:28 28人阅读 评论(0) 收藏

    Gibonacci number Time Limit: 2 Seconds      Memory Limit: 65536 KB In mathematical terms, the normal ...

随机推荐

  1. 代码质量检测(SonarQube)整合中文版+阿里P3C

    代码质量检测(SonarQube)整合中文版+阿里P3C 简介 SonarQube是一种自动代码审查工具,用于检测代码中的错误,漏洞和代码异味.它可以与您现有的工作流程集成,以便在项目分支和拉取请求之 ...

  2. Python二元操作符

    def quiz_message(grade): outcome = 'failed' if grade<50 else 'passid' print ('grade', grade, 'out ...

  3. TensorFlow读取数据的三种方法

    tensortlfow数据读取有三种方式 placehold feed_dict:从内存中读取数据,占位符填充数据 queue队列:从硬盘读取数据 Dataset:同时支持内存和硬盘读取数据 plac ...

  4. ACM团队招新赛题解

    标程代码全部为C语言编写.代码中的#if LOCAL_ 至#endif为本地一些调试内容,可以忽略. Xenny的A+B(1)[容易][签到] 签到题,做不出的话可能你有点不太适合ACM了. Xenn ...

  5. Tomcat乱码

    日志乱码修改logging.properties文件中encoding=UTF-8 vim logging.properties encoding=utf-8 wq!保持退出,重启tomcat 乱码O ...

  6. 【读书笔记】C++ primer 5th 从入门到自闭(一)

    这几天看了C++ primer 5th的一二章,有很多收获,但是有的地方因为翻译的问题也搞得理解起来颇为难受啊啊啊啊.尤其是const限定符,在C语言并没有这么多复杂的语法,在C++里面语法细节就多的 ...

  7. .netCore+Vue 搭建的简捷开发框架 (3)-- Services层实现

    继续交作业: 上一篇作业中我们实现了 Repository仓储层的应用.并为我们的框架引入了EFCore 详见: .netCore+Vue 搭建的简捷开发框架 (2)--仓储层实现和EFCore 的使 ...

  8. Spring Boot(二) 配置文件

    文章导航-readme 一.配置Spring Boot热部署     技术的发展总是因为人们想偷懒的心理,如果我们不想每次修改了代码,都必须重启一下服务器,并重新运行代码.那么可以配置一下热部署.有了 ...

  9. 【深度学习】Focal Loss 与 GHM——解决样本不平衡问题

    Focal Loss 与 GHM Focal Loss Focal Loss 的提出主要是为了解决难易样本数量不平衡(注意:这有别于正负样本数量不均衡问题)问题.下面以目标检测应用场景来说明. 一些 ...

  10. Redis 集群(三)

    为什么为有集群 在 Redis3 版本之前,每台 Redis 机器需要存储所有 Redis key ,这要求每台 Redis 机器有足够大的内存 而且只能是主节点写,从节点读,对于高并发情况下会有性能 ...