题解 SP13015
题目描述:
给定初始序列 \(A\),然后对原序列有以下操作:
- 操作 \(1\):
0 l r v将区间 \([l,r]\) 全赋值为 \(v\)。 - 操作 \(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的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- [自然语言处理] 自然语言处理库spaCy使用指北
spaCy是一个基于Python编写的开源自然语言处理库.基于自然处理领域的最新研究,spaCy提供了一系列高效且易用的工具,用于文本预处理.文本解析.命名实体识别.词性标注.句法分析和文本分类等任务 ...
- 用Claude-2-100K复刻了胡锡进老师的写作风格
大家好,我是老章 最近玩心大发,用Claude-2-100K复刻了胡锡进老师的写作风格,然后用这个风格点评世间万物. 蛮有意思的,直接看效果吧: 怎么实现的呢?老章不喜欢废话,极简介绍一下步骤. 第一 ...
- Uncaught TypeError: Failed to set the 'currentTime' property on 'HTMLMediaElement': The provided double value is non-finite.
musicSeekTo: function(value){this.audio.currentTime = this.audio.duration*value; }, musicVoiceSeekTo ...
- Android 架构模式如何选择
作者:vivo 互联网客户端团队-Xu Jie Android架构模式飞速演进,目前已经有MVC.MVP.MVVM.MVI.到底哪一个才是自己业务场景最需要的,不深入理解的话是无法进行选择的.这篇文章 ...
- 26194136 psu安装步骤
26194136 psu安装步骤 1.拷贝 安装包p26194136_112040_MSWIN-x86-64.zip到 目录 2..关闭rac crsctl stop crs srvctl stop ...
- 【技术积累】Linux中的命令行【理论篇】【三】
apt-get命令 命令介绍 Debian Linux发行版中的APT软件包管理工具,apt-get命令 是Debian Linux发行版中的APT软件包管理工具.所有基于Debian的发行都使用这个 ...
- 【Leaflet入门篇】 Leaflet快速入门
0 前言 Leaflet 是一个开源并且对移动端友好的交互式地图 JavaScript 库. 它大小仅仅只有 42 KB of JS, 并且拥有绝大部分开发者所需要的所有地图特性 .Leaflet 简 ...
- npm与package.json的联系
在nodejs编写的脚手架项目中,npm是不可缺少的包管理工具,当使用npm初始化时,会生成package.json文件来对项目进行整体的管理和描述 以下是新建的练习项目中package.json ...
- [linux]常见内核TCP参数描述与配置
前言 所有的TCP/IP参数都位于/proc/sys/net目录下(请注意,对/proc/sys/net目录下内容的修改都是临时的,任何修改在系统重启后都会丢失),如果需要固化设置,则需要修改/etc ...
- [k8s]使用私有harbor镜像源
前言 在node上手动执行命令可以正常从harbor拉取镜像,但是用k8s不行,使用kubectl describe pods xxx 提示未授权 unauthorized to access rep ...