题解 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 ...
随机推荐
- 想在golang里用好泛型还挺难的
golang的泛型已经出来了一年多了,从提案被接受开始我就在关注泛型了,如今不管是在生产环境还是开源项目里我都写了不少泛型代码,是时候全面得回顾下golang泛型的使用体验了. 先说说结论,好用是好用 ...
- Flutter系列文章-Flutter进阶
在前两篇文章中,我们已经了解了Flutter的基础知识,包括Flutter的设计理念.框架结构.Widget系统.基础Widgets以及布局.在本文中,我们将进一步探讨Flutter的高级主题,包括处 ...
- Redis从入门到放弃(8):哨兵模式
在前面的文章中介绍了Redis的主从复制,但主从复制存在一定的缺陷.如果Master节点宕机,因为不具备自动恢复功能,需要人工干预,那么在这个干预过程中Redis将不可用. 为了解决这一问题,Redi ...
- LabVIEW图形化的AI视觉开发平台(非NI Vision)VI简介
前言 今天想和大家分享的是:仪酷LabVIEW AI视觉工具包的VI简介,如介绍内容有误,欢迎各位朋友们帮忙纠正~ 一.AI视觉工具包VI简介 已经安装好的AI工具包位于程序框图-函数选板-Addon ...
- 【技术积累】Linux中的命令行【理论篇】【七】
atrm命令 命令介绍 atrm命令是Linux系统中的一个命令行工具,用于取消或删除已经安排的at命令.at命令是一种用于在指定时间执行一次性任务的工具. 命令说明 atrm命令的语法如下: atr ...
- 产品代码都给你看了,可别再说不会DDD(一):DDD入门
这是一个讲解DDD落地的文章系列,作者是<实现领域驱动设计>的译者滕云.本文章系列以一个真实的并已成功上线的软件项目--码如云(https://www.mryqr.com)为例,系统性地讲 ...
- 2、Spring之IOC概述
2.1.IOC思想 2.1.1.传统方式获取资源 组件主动地从容器中获取所需要的资源,在这样的模式下开发人员往往需要知道在具体容器中特定资源的获取方式: 提高了学习成本,同时也降低了开发的效率. 2. ...
- 三维模型OSGB格式轻量化的跨平台兼容性技术分析
三维模型OSGB格式轻量化的跨平台兼容性技术分析 在三维模型应用中,OSGB格式轻量化处理是一种常见的技术手段,可以通过数据压缩.简化.滤波等操作,降低三维模型数据的存储空间和传输带宽需求,提高应用程 ...
- 通过Scrum实现最大生产力的五种方法
在数字化.信息化.智能化蓬勃发展的今天,敏捷开发和Scrum已成为重塑项目管理的重要方式. 敏捷是一种体现不同方法的思维方式,包括了Scrum,看板,极限编程(XP).精益开发等众多框架. Scrum ...
- GitHub Actions CI/CD 工作流实战
1. 什么是 GitHub Actions 与 workflow ? GitHub Actions 是 GitHub 提供的一种持续集成(CI)和持续部署(CD)的工具,用于自动化软件开发过程中的各种 ...