这道题我改啊,改啊,交啊,就对了。

#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的更多相关文章

  1. 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 ...

  2. ZOJ 3911 Prime Query(线段树)

    Prime Query Time Limit: 1 Second      Memory Limit: 196608 KB You are given a simple task. Given a s ...

  3. Prime Query (ZOJ 3911 线段树)

    Prime Query Time Limit: 1 Second Memory Limit: 196608 KB You are given a simple task. Given a sequen ...

  4. 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 ...

  5. ZOJ 5638——Prime Query——————【线段树区间更新,区间查询,单点更新】

    Prime Query Time Limit: 1 Second      Memory Limit: 196608 KB You are given a simple task. Given a s ...

  6. 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 可以参考一下部 ...

  7. 【LGR-054】洛谷10月月赛II

    [LGR-054]洛谷10月月赛II luogu 成功咕掉Codeforces Round #517的后果就是,我\(\mbox{T4}\)依旧没有写出来.\(\mbox{GG}\) . 浏览器 \( ...

  8. First Scrum Meeting (2015/10/18)

    会议是在昨晚进行的,本来早就应该写博了,可惜今天校园网炸个不停= =.刚修好就赶紧来发博客. 会议基本要素 会议主题:爬虫项目的核心技术讨论以及项目初期的工作分配 会议时间:2015.10.18 19 ...

  9. 2015/10/9 Python核编初级部分学习总结

    终于在十一长假之后的两天看完了<Python核心编程>的初级部分.虽然到后来两章,类和环境看得越来越慢,越来越难以理解.很多东西只能靠强记,也没办法真正掌握了,我想了想,还是不强迫自己去背 ...

随机推荐

  1. [ZETCODE]wxWidgets教程四:菜单栏和工具栏

    本教程原文链接:http://zetcode.com/gui/wxwidgets/menustoolbars/ 翻译:瓶哥 日期:2013年11月28日星期四 邮箱:414236069@qq.com ...

  2. hdoj 2816 I Love You Too

    I Love You Too Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. 关于 vim每次w时都提示 “E509: 无法创建备份文件 (请加 ! 强制执行)”

    今天网上git下vim的配置后v只要执行:wq就会出现这样的话,找了点资料说是没有.vimbk文件夹,我加了也没用,后来发现在root权限下就不会出现这样的问题,然后我就把当前文件夹下所以的有关vim ...

  4. 在IDE中用Bing Code Search直接查找代码片段并且插入

    博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:在IDE中用Bing Code Search直接查找代码片段并且插入.

  5. CAS SSO:汇集配置过程中的错误解决方法

    本教程为gevin.me原创文章,转载请注明: CAS SSO:配置过程中的错误解决方法 | Gevin’s Blog 本文将收集在配置CAS SSO遇到的所有错误,希望对大家有帮助,也方便下次搭建的 ...

  6. hibernate中持久化对象的生命周期(三态:自由态,持久态,游离态 之间的转换)

    三态的基本概念: 1,  暂时状态(Transient):也叫自由态,仅仅存在于内存中,而在数据库中没有对应数据.用new创建的对象,它没有持久化,没有处于Session中,处于此状态的对象叫暂时对象 ...

  7. PMP考试的过与只是

    我在一年多时间里參加了三次PMP考试,前两次都失败,直到第三次才成功.怎样对待失败?这是每个人都会遇到的挑战.假设我们能用正确的态度对待临时的失败,那么终于的成功也就不远了.我希望通过本文与大家分享一 ...

  8. 错误ERROR datanode.DataNode (DataXceiver.java:run(278)) - hadoop07:50010DataXceiver error processing unknown operation src:127.0.0.136479 dst:127.0.0.150010

    原因: Ambari 每分钟会向datanode发送"ping"连接一下去确保datanode是正常工作的.否则它会触发alert.但是datanode并没有处理空内容的逻辑,所以 ...

  9. 使用 JSSE 定制 SSL 连接的属性--转载

    当数据在网络上传播的时候,通过使用 SSL 对其进行加密和保护,JSSE 为 Java 应用程序提供了安全的通信.在本篇有关该技术的高级研究中,Java 中间件开发人员 Ian Parkinson 深 ...

  10. 获取IMEI码

    核心代码: Imei = ((TelephonyManager) getSystemService(TELEPHONY_SERVICE)).getDeviceId(); 1.加入权限 在manifes ...