ZOJ 2015 10月份 月赛 3911 Prime Query
这道题我改啊,改啊,交啊,就对了。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = ;
const int M = ;
int a[N];
int p[M];
int tree[M*],cover[M*];
void Prime()
{
a[] = ;
for (int i=; i<sqrt(N); i++) {
if(a[i]);
else{
for (int j=*i; j<N ;j+=i) {
a[j]=;
}
}
}
}
void down(int i,int l,int r)
{ int k;
int mid=(l+r)>>;
if (cover[i] != -)
{
if(l!=r){cover[i<<]=cover[i<<|]=cover[i];
if(!a[cover[i]])k=;
else k=;
tree[i<<]=k*(mid-l+);
tree[i<<|]=k*(r-mid);}
else p[l]=cover[i];
cover[i]=-;
}
}
void build(int rt,int l,int r)
{
if(l==r){
if(!a[p[l]])
tree[rt]=;
else tree[rt]=;
return;
}
int mid=(l+r)>>;
build(rt<<,l,mid);
build(rt<<|,mid+,r);
tree[rt]=tree[rt<<]+tree[rt<<|];
}
void A(int v,int l,int rt,int L,int R)
{ down(rt,L,R);
if(L==R){
if(!a[p[l]+=v])
tree[rt]=;
else tree[rt]=;
return;
} int mid=(L+R)>>;
if(l<=mid)A(v,l,rt<<,L,mid);
if(l>mid)A(v,l,rt<<|,mid+,R);
tree[rt]=tree[rt<<]+tree[rt<<|];
}
int Q(int l,int r,int rt,int L,int R)
{ down(rt,L,R);
if(L>=l&&R<=r){
return tree[rt];
}
int ans=; int mid=(L+R)>>;
if(l<=mid)ans+=Q(l,r,rt<<,L,mid);
if(r>mid)ans+=Q(l,r,rt<<|,mid+,R);
return ans;
}
void Re(int k,int l,int r,int rt,int L,int R)
{down(rt,L,R);
if(L>=l&&R<=r){
if(!a[k])
tree[rt]=R-L+;
else tree[rt]=;
cover[rt]=k;
return;
} int mid=(L+R)>>;
if(l<=mid)Re(k,l,r,rt<<,L,mid);
if(r>mid)Re(k,l,r,rt<<|,mid+,R);
tree[rt]=tree[rt<<]+tree[rt<<|];
}
int main() {
Prime();
int T,n,m;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
scanf("%d",&p[i]);
}
build(,,n);
memset(cover,-,sizeof cover);
char s[];
while(m--)
{
scanf("%s",s);
if(s[]=='A')
{
int v,l;
scanf("%d%d",&v,&l);
A(v,l,,,n);
//for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
else if(s[]=='Q')
{
int l,r;
scanf("%d%d",&l,&r);
printf("%d\n",Q(l,r,,,n));
//for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
else if(s[]=='R')
{
int x,l,r;
scanf("%d%d%d",&x,&l,&r);
Re(x,l,r,,,n);
// for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
}
}
}
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 10000005;
const int M = 100005;
int a[N];
int p[M];
int tree[M*4],cover[M*4];
void Prime()
{
a[1] = 1;
for (int i=2; i<sqrt(N); i++) {
if(a[i]);
else{
for (int j=2*i; j<N ;j+=i) {
a[j]=1;
}
}
}
}
void down(int i,int l,int r)
{
int k;
int mid=(l+r)>>1;
if (cover[i] != -1)
{
if(l!=r){cover[i<<1]=cover[i<<1|1]=cover[i];
if(!a[cover[i]])k=1;
else k=0;
tree[i<<1]=k*(mid-l+1);
tree[i<<1|1]=k*(r-mid);}
else p[l]=cover[i];
cover[i]=-1;
}
}
void build(int rt,int l,int r)
{
if(l==r){
if(!a[p[l]])
tree[rt]=1;
else tree[rt]=0;
return;
}
int mid=(l+r)>>1;
build(rt<<1,l,mid);
build(rt<<1|1,mid+1,r);
tree[rt]=tree[rt<<1]+tree[rt<<1|1];
}
void A(int v,int l,int rt,int L,int R)
{ down(rt,L,R);
if(L==R){
if(!a[p[l]+=v])
tree[rt]=1;
else tree[rt]=0;
return;
}
int mid=(L+R)>>1;
if(l<=mid)A(v,l,rt<<1,L,mid);
if(l>mid)A(v,l,rt<<1|1,mid+1,R);
tree[rt]=tree[rt<<1]+tree[rt<<1|1];
}
int Q(int l,int r,int rt,int L,int R)
{ down(rt,L,R);
if(L>=l&&R<=r){
return tree[rt];
}
int ans=0;
int mid=(L+R)>>1;
if(l<=mid)ans+=Q(l,r,rt<<1,L,mid);
if(r>mid)ans+=Q(l,r,rt<<1|1,mid+1,R);
return ans;
}
void Re(int k,int l,int r,int rt,int L,int R)
{down(rt,L,R);
if(L>=l&&R<=r){
if(!a[k])
tree[rt]=R-L+1;
else tree[rt]=0;
cover[rt]=k;
return;
}
int mid=(L+R)>>1;
if(l<=mid)Re(k,l,r,rt<<1,L,mid);
if(r>mid)Re(k,l,r,rt<<1|1,mid+1,R);
tree[rt]=tree[rt<<1]+tree[rt<<1|1];
}
int main() {
Prime();
int T,n,m;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%d",&p[i]);
}
build(1,1,n);
memset(cover,-1,sizeof cover);
char s[10];
while(m--)
{
scanf("%s",s);
if(s[0]=='A')
{
int v,l;
scanf("%d%d",&v,&l);
A(v,l,1,1,n);
//for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
else if(s[0]=='Q')
{
int l,r;
scanf("%d%d",&l,&r);
printf("%d\n",Q(l,r,1,1,n));
//for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
else if(s[0]=='R')
{
int x,l,r;
scanf("%d%d%d",&x,&l,&r);
Re(x,l,r,1,1,n);
// for(int i=1;i<=n;i++)printf("%d ",p[i]);
// puts("");
}
}
}
}
ZOJ 2015 10月份 月赛 3911 Prime Query的更多相关文章
- ZOJ 3911 Prime Query ZOJ Monthly, October 2015 - I
Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a s ...
- ZOJ 3911 Prime Query(线段树)
Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a s ...
- Prime Query (ZOJ 3911 线段树)
Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a sequen ...
- 143 - ZOJ Monthly, October 2015 I Prime Query 线段树
Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a s ...
- ZOJ 5638——Prime Query——————【线段树区间更新,区间查询,单点更新】
Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a s ...
- 4分钟apache自带ab压力测试工具使用: 2015.10.4
2015.10.44分钟apache自带ab压力测试工具使用:win8.1 wampserver2.5 -Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b 可以参考一下部 ...
- 【LGR-054】洛谷10月月赛II
[LGR-054]洛谷10月月赛II luogu 成功咕掉Codeforces Round #517的后果就是,我\(\mbox{T4}\)依旧没有写出来.\(\mbox{GG}\) . 浏览器 \( ...
- First Scrum Meeting (2015/10/18)
会议是在昨晚进行的,本来早就应该写博了,可惜今天校园网炸个不停= =.刚修好就赶紧来发博客. 会议基本要素 会议主题:爬虫项目的核心技术讨论以及项目初期的工作分配 会议时间:2015.10.18 19 ...
- 2015/10/9 Python核编初级部分学习总结
终于在十一长假之后的两天看完了<Python核心编程>的初级部分.虽然到后来两章,类和环境看得越来越慢,越来越难以理解.很多东西只能靠强记,也没办法真正掌握了,我想了想,还是不强迫自己去背 ...
随机推荐
- C语言练习题_邮票组合
背景: 我们寄信都要贴邮票,在邮局有一些小面值的邮票,通过这些小面值邮票中的一张或几张的组合,可以满足不同邮件的不同的邮资. 现在,邮局有4种不同面值的邮票.在每个信封上最 ...
- 打开U盘里是U盘的快捷方式?(2013.12.05)
昨天去打印室打印,结果U盘就中招了 症状: 我的U盘: 打开变成了里面: ...
- 一个空格引发的bug
好久没写博客了. 我们的一个项目用的thinkphp框架,当在debug模式下面运行很正常,但切换到生产模式时,刷新页面第一次可以正常显示,刷新第二次会出现错误如下: Fatal error: Cal ...
- 微信小程序正式发布!这是最全的上手指南
2017 年 1 月 9 日,是一个值得载入互联网史册的日子. 这一天,零点刚过,张小龙和他的团队,在夜色笼罩下,正式发布了微信小程序. 所以,从这一刻开始,只要有开发者登录小程序后台,并在「开发管理 ...
- LCD深度剖析
LCD 深度剖析 来源:http://blog.csdn.net/hardy_2009/article/details/6922900 http://blog.csdn.net/jaylondon/a ...
- Request的getParameter和getAttribute方法的区别
下面整理一下getParameter和getAttribute的区别和各自的使用范围. (1)HttpServletRequest类有setAttribute()方法,而没有setParam ...
- android85 短信防火墙
系统收到短信是有广播的,广播中包含了短信的号码和内容 ###短信防火墙 * 系统发送短信广播时,是怎么把短信内容存入广播的,我们就只能怎么取出来 * 如果短信过长,那么发送时会拆分成多条短信发送,那么 ...
- oracle16 例外
例外处理 例外的分类 oracle将例外分为预定义例外,非预定义例外和自定义例外三种. 预定义例外用于处理常见的oracle错误 非预定义例外用于处理预定义例外不能处理的例外 自定义例外用于处理与or ...
- C# DataTable怎么合计字段
DataTable dt = new DataTable(); var age=dt.Compute("avg(age)",""); var height =d ...
- 指针做MAP的KEY的TEST
用struct做map的key会需要"operator <"等等,还会出现奇怪的问题可能. 试了下用指针做key,看看效果: #include <iostream> ...