码迷,mamicode.com
首页 > 其他好文 > 详细

HDU6186 2017广西邀请赛 CS Course (前缀和后缀)

时间:2018-05-26 19:43:32      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:IV   print   get   http   amp   i++   target   ios   tar   

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6186

思路:题目要求的删除第q个数候所有数的 & | ^和,所以提前求出前缀和后缀,每次& | ^ 前i-1个和后i+1个即可。注意a^b^b=a;

#include <iostream>
#include <cstdio>

using namespace std;

const long long maxn=1e5+10;

int n,q;
long long f1[maxn],f2[maxn];
long long e1[maxn],e2[maxn];
long long a[maxn];

int main()
{
    while(~scanf("%d%d",&n,&q))
    {
        for(int i=1;i<=n;i++)
    {
        scanf("%lld",&a[i]);
    }
    f1[1]=f2[1]=a[1];
    long long ans=a[1];
    for(int i=2;i<=n;i++)
    {
        f1[i]=f1[i-1]&a[i];
        f2[i]=f2[i-1]|a[i];
        ans^=a[i];
    }
    e1[n]=e2[n]=a[n];
    for(int i=n-1;i>=1;i--)
    {
        e1[i]=e1[i+1]&a[i];
        e2[i]=e2[i+1]|a[i];

    }
    while(q--)
    {
        int x;
        cin>>x;
        if(x==1) printf("%lld %lld %lld\n",e1[2],e2[2],a[x]^ans);
        else if(x==n) printf("%lld %lld %lld\n",f1[x-1],f2[x-1],a[x]^ans);
        else printf("%lld %lld %lld\n",f1[x-1]&e1[x+1],f2[x-1]|e2[x+1],a[x]^ans);
    }
    }

    return 0;
}

 

HDU6186 2017广西邀请赛 CS Course (前缀和后缀)

标签:IV   print   get   http   amp   i++   target   ios   tar   

原文地址:https://www.cnblogs.com/Fy1999/p/9093866.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!