首页 > 其他 > 详细

HDU 6186 CS Course(前缀+后缀)

时间:2018-07-14 16:07:28      阅读:180      评论:0      收藏:0      [点我收藏+]

http://acm.hdu.edu.cn/showproblem.php?pid=6186

题意:
给出n个数,共有n次询问,每次询问给出一个数p,求除去第p个数后的n-1个数的&、|、^值。

 

思路:
分别计算出&、|、^的前缀和后缀,将前缀和后缀相计算即可。

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<algorithm>
 4 using namespace std;
 5 const int maxn = 1e5+5;
 6 
 7 int n, q;
 8 int a[maxn], prea[maxn], suffa[maxn], preo[maxn], suffo[maxn], prex[maxn], suffx[maxn];
 9 
10 int main()
11 {
12     //freopen("in.txt","r",stdin);
13     while(~scanf("%d%d",&n,&q))
14     {
15         scanf("%d",&a[1]);
16         prea[1] = preo[1] = prex[1] = a[1];
17         for(int i=2;i<=n;i++)
18         {
19             scanf("%d",&a[i]);
20             prea[i] = a[i] & prea[i-1];
21             preo[i] = a[i] | preo[i-1];
22             prex[i] = a[i] ^ prex[i-1];
23         }
24         suffa[n] = suffo[n] = suffx[n] = a[n];
25         for(int i=n-1;i>=1;i--)
26         {
27             suffa[i] = a[i] & suffa[i+1];
28             suffo[i] = a[i] | suffo[i+1];
29             suffx[i] = a[i] ^ suffx[i+1];
30         }
31         while(q--)
32         {
33             int pos; scanf("%d",&pos);
34             int ans1 = prea[pos-1] & suffa[pos+1];
35             int ans2 = preo[pos-1] | suffo[pos+1];
36             int ans3 = prex[pos-1] ^ suffx[pos+1];
37             if(pos==1)
38             {
39                 ans1 = suffa[pos+1];
40                 ans2 = suffo[pos+1];
41                 ans3 = suffx[pos+1];
42             }
43             if(pos==n)
44             {
45                 ans1 = prea[pos-1];
46                 ans2 = preo[pos-1];
47                 ans3 = prex[pos-1];
48             }
49             printf("%d %d %d\n", ans1, ans2, ans3);
50         }
51     }
52     return 0;
53 }

 

HDU 6186 CS Course(前缀+后缀)

原文:https://www.cnblogs.com/zyb993963526/p/9309683.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!