题目描述:

给定初始序列 \(A\),然后对原序列有以下操作:

  1. 操作 \(1\): 0 l r v 将区间 \([l,r]\) 全赋值为 \(v\)。
  2. 操作 \(2\):1 l r 查询区间 \([l,r]\) 的质数个数。

注意:多组测试和特殊的输出。

题目分析:

就是一道板子题,首先我们先用欧拉筛筛出值域 \([2,10^6]\) 内的素数并开桶打标记(实际上一个欧拉筛就行了)。

此时,线段树维护的是当前区间内质数的个数,我们可以将操作 \(1\) 变成如下操作:

  • 若 \(v\) 属于质数,则将区间 \([l,r]\) 内的数全赋值成 \(1\)。
  • 若 \(v\) 不属于质数,则将区间 \([l,r]\) 内的数全赋值成 \(0\)。

那么,操作 \(2\) 此时显然就变成了一个区间求和。

时间复杂度,\(O(n\lg n)\)。

代码实现:

#include <bits/stdc++.h>
#define dbg(x) cerr<<#x<<": "<<x<<endl;
using namespace std;
#define MAX_SIZE (int)2e6
#define MAX_RANGE (int)1.1e6 bool nf[MAX_RANGE];
int primes[MAX_RANGE];
inline void primeshai(int n){
for(register int i=2;i<=n;i++){
if(!nf[i])
primes[++primes[0]] = i;
for(register int j=1;j<=primes[0]&&primes[j]*i<=n;j++){
nf[primes[j]*i] = 1;
if(i%primes[j]==0)
break;
}
}
} inline int read()
{
int x=0,f=1;char ch=getchar();
while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}
while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
return x*f;
} struct SegmentTree{
int sum;
int lazy;
int l,r;
int len;
};
SegmentTree seg[MAX_SIZE<<2];
int a[MAX_SIZE]; void build(int p,int l,int r)
{
seg[p].l = l;
seg[p].r = r;
seg[p].lazy = -1;
seg[p].len = r-l+1;
if(l==r){
seg[p].sum = !nf[a[l]];
return;
}
int mid = (l+r)>>1;
build(p<<1,l,mid);
build(p<<1|1,mid+1,r);
seg[p].sum = seg[p<<1].sum + seg[p<<1|1].sum;
} inline void spread(int p){
if(seg[p].lazy!=-1){
seg[p<<1].sum = seg[p].lazy*seg[p<<1].len;
seg[p<<1|1].sum = seg[p].lazy*seg[p<<1|1].len;
seg[p<<1].lazy = seg[p].lazy;
seg[p<<1|1].lazy = seg[p].lazy;
seg[p].lazy = -1;
}
} inline void modify(int p,int l,int r,int val){
if(l<=seg[p].l&&r>=seg[p].r){
seg[p].sum = val * seg[p].len;
seg[p].lazy = val;
return;
}
if(seg[p].lazy>=0)
spread(p);
int mid = (seg[p].l+seg[p].r)>>1;
if(l<=mid)
modify(p<<1,l,r,val);
if(r>mid)
modify(p<<1|1,l,r,val);
seg[p].sum = seg[p<<1].sum + seg[p<<1|1].sum;
} inline int query(int p,int l,int r){
if(l<=seg[p].l&&r>=seg[p].r)
return seg[p].sum;
if(seg[p].lazy>=0)
spread(p);
int val = 0;
int mid = (seg[p].l+seg[p].r)>>1;
if(l<=mid)
val += query(p<<1,l,r);
if(r>mid)
val += query(p<<1|1,l,r);
return val;
} int main(){
ios::sync_with_stdio(false);
cout.tie(0);
#ifdef LOCAL
freopen("in.in","r",stdin);
freopen("out.out","w",stdout);
double c1 = clock();
#endif
//============================================
primeshai(1e6);
int T;
T = read();
for(int x=1;x<=T;x++){
cout<<"Case "<<x<<':'<<endl;
int n = read();
int q = read();
for(int i=1;i<=n;i++)
a[i] = read();
build(1,1,n);
while(q--){
switch(read()){
case 0:{
int l = read();
int r = read();
int y = read();
modify(1,l,r,!nf[y]);
break;
}
case 1:{
int l = read();
int r = read();
cout<<query(1,l,r)<<endl;
break;
}
}
}
}
//============================================
#ifdef LOCAL
double c2 = clock();
cerr<<"Used Time: "<<c2-c1<<"ms"<<endl;
if(c2-c1>1000)
cerr<<"Warning!! Time Limit Exceeded!!"<<endl;
fclose(stdin);
fclose(stdout);
#endif
return 0;
}

题解 SP13015的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. 懒人的百宝箱「GitHub 热点速览」

    本周 GitHub Trending 除了 lazydocker 之外,还有多个 lazy 项目上线,比如大家熟悉的 lazyvim,可见,这个世界对懒人还是很友好的.除此之外,主打一个密码免输入,绕 ...

  2. js 文字像打字一样缓缓出现

    点击查看代码 <!DOCTYPE HTML> <html lang="en"> <head> <meta charset="UT ...

  3. Maven资源导出问题所需配置

    <!--在build中配置resources,来防止我们资源导出失败的问题--> <build> <resources> <resource> < ...

  4. SimpleDateFormat 线程安全问题修复方案

    问题介绍 在日常的开发过程中,我们不可避免地会使用到 JDK8 之前的 Date 类,在格式化日期或解析日期时就需要用到 SimpleDateFormat 类,但由于该类并不是线程安全的,所以我们常发 ...

  5. 3.你不知道的go语言控制语句

    目录 本篇前瞻 Leetcode习题9 题目描述 题目分析 代码编写 知识点归纳 控制结构 顺序结构(Sequence) 声明和赋值 算术运算符 位运算符 逻辑运算 分支结构 if 语句 switch ...

  6. 论文解读(CTDA)《Contrastive transformer based domain adaptation for multi-source cross-domain sentiment classification》

    Note:[ wechat:Y466551 | 可加勿骚扰,付费咨询 ] 论文信息 论文标题:Contrastive transformer based domain adaptation for m ...

  7. BUGKU逆向reverse 1-8题

    练习IDA两年半 打开尘封已久的bugku,从题目中练习使用,现在都已经是新版本了 orz 入门逆向 运行baby.exe将解压后的baby.exe拖到IDA里面主函数中找到mov指令 可以看到这里就 ...

  8. Git-更换服务器问题

    一.Permission denied (publickey) git指令出现Permission denied (publickey),是ssh key过期的问题,需要对ssh key进行更新,所有 ...

  9. 《SQLi-Labs》03. Less 11~15

    @ 目录 索引 Less-11 题解 原理 Less-12 题解 Less-13 题解 Less-14 题解 Less-15 题解 原理 sqli.开启新坑. 索引 Less-11:POST 回显注入 ...

  10. Python 创建或读取 Excel 文件

    Excel是一种常用的电子表格软件,广泛应用于金融.商业和教育等领域.它提供了强大的数据处理和分析功能,可进行各种计算和公式运算,并能创建各种类型的图表和可视化数据.Excel的灵活性使其成为处理和管 ...