加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

【数据结构】第1周 线性表 3:位查询

发布时间:2020-12-15 06:32:01 所属栏目:安全 来源:网络整理
导读:3:位查询 查看 提交 统计 提问 总时间限制: 5000ms 内存限制: 65536kB 描述 给出N个范围在[0,65535]的整数,编程支持以下的操作: (1)修改操作:C d,所有的数都增加d。如果超过65535,把结果模65536。 0 = d = 65535 (2)查询操作:Q i,统计在N个正整数

3:位查询

  • 查看
  • 提交
  • 统计
  • 提问
总时间限制:
5000ms
内存限制:
65536kB
描述

给出N个范围在[0,65535]的整数,编程支持以下的操作:


(1)修改操作:C d,所有的数都增加d。如果超过65535,把结果模65536。 0 <= d <= 65535
(2)查询操作:Q i,统计在N个正整数中有多少个整数其对应的二进制形式的第i位二进制位为非0。0 <= i <= 15。并且最低位i为0。


  最后,输出所有查询操作的统计值。

输入
输入的第一行为两个正整数N,M,其中N为操作的整数的个数,而M为具体有多少个操作。
输入的第二行为N个正整数,为进行操作的N个正整数。
下面有M行,分别表示M个操作。

N<=100000,M<=200000
输出
输出所有查询操作Q的统计值,每一个查询操作统计结果输出为一行。
样例输入
3 5
1 2 4
Q 1
Q 2
C 1
Q 1
Q 2
样例输出
1
1
2
1
提示
只输出查询操作Q的统计值。
# include<stdio.h>

int a[100005],b[200005];

int main(void)
{
    char c[2];
    int i,N,k,j,cnt,t=0;

    scanf("%d%d",&N,&M);
    for(i=0; i<N; i++)
    scanf("%d",&a[i]);
    for(i=0; i<M; i++)
    {
        scanf("%s%d",c,&k);
        if(c[0]=='C')
        {
            for(j=0; j<N; j++)
            a[j]=(a[j]+k)%65536;
        }
        else
        {
            cnt=0;
            for(j=0; j<N; j++)
            {
                if(a[j]&(1<<k))
                {
                    cnt++;
                }
            }
            b[t++]=cnt;
        }
    }
    for(i=0; i<t; i++)
    printf("%dn",b[i]);

    return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读