Data Structure

题目描述

将一个非负整数序列划分为 \(K\) 段,分别计算出各段中的整数按位或的结果,然后再把这些结果按位与起来得到一个最终结果,把这个最终结果定义为这个序列的一个 \(K−or−and\) 值。

比如序列为 \([1,5,9,2],K=2\),如果划分为 \([1,5],[9,2]\),那么 \(K−or−and\) 值为 \((1or5)and(9or2)=1\)。当然划分可能不止一种,所以 \(K−or−and\) 值也可能不止一个。

给定一个长度为 \(N\) 的非负整数序列 \(A_1A_2A_3\dots A_N\),一个整数 \(K\) 和以下三种操作:

  1. 给定一个整数 \(x\) ,把序列中的所有数字按位或上 \(x\)。即\(\forall i\in [1,N],A_i=A_i \ or \ x\)。

  2. 给定一个整数 \(x\),把序列中的所有数字按位与上 \(x\)。即\(\forall i\in [1,N],A_i=A_i \ and \ x\)。

  3. 查询当前序列最大的 \(K−or−and\) 值。

lililalala太菜了,他希望你来帮他解决这个问题。

输入描述:

第一行两个整数 \(N,K(1\le K\le N\times 2\times 10^5)\) -序列长度和划分的段数。

第二行 \(N\)个整数 \(A_1A_2A_3\dots A_N( 0\le A_1,A_2,A_3\dots A_N<2^{31})\)。

第三行一个整数 \(Q(1\le Q\le 2\times 10^5)\)--操作的数量。

然后 \(Q\) 行其中第 \(i\)行为以下三种格式之一:

\(1x_i\)--把序列中的所有数字按位或上 \(x_i(0\le x_i<2^{31})\)。

\(2x_i\)--把序列中的所有数字按位与上 \(x_i(0\le x_i<2^{31})\)。

\(3\)--查询当前序列最大的 \(K−or−and\) 值。

输出描述:

对于每次查询(操作 \(3\) )输出一行一个整数作为查询结果。


昨天晚上云做题,看了看C和D

然后成功嘴巴出做法,但是一直wa,今天顺手改一改,C比较简单,不管了

先不管修改,我们直接看看怎么求原序列的答案

显然可以按位贪心

如果我们可以确定高\(i\)位的答案为\(ans\),那么考虑\(i+1\)位是否可以取\(1\),可以直接贪心考虑

从左到右扫\(A\)数组,如果当前前缀异或值\(x\)可以拼出高\(i+1\)位的所有\(1\),就搞一个分割。

这样显然可以最大化分割。

然后复杂度\(n \log A_i\)

考虑操作每次会把所有的某一位取\(0\)或者\(1\),如果某一维被取过,这一位就不用管了。

发现这样最多有\(\log A_i\)个位被第一次全部取\(0\)或者\(1\)

那么直接每次暴力就好了

复杂度\(O(n\log^2 A)\)


Code:

#include <cstdio>
#include <cctype>
const int SIZE=1<<21;
char ibuf[SIZE],*iS,*iT;
//#define gc() (iS==iT?(iT=(iS=ibuf)+fread(ibuf,1,SIZE,stdin),iS==iT?EOF:*iS++):*iS++)
#define gc() getchar()
template <class T>
void read(T &x)
{
x=0;char c=gc();
while(!isdigit(c)) c=gc();
while(isdigit(c)) x=x*10+c-'0',c=gc();
}
const int N=2e5+10;
int yuy[32],a[N];
int n,k,Q,ans;
void getans()
{
ans=0;
for(int j=30;~j;j--)
{
if(yuy[j]!=-1) continue;
int cnt=0,x=0;
ans|=1<<j;
for(int i=1;i<=n;i++)
{
x|=a[i];
if((ans&x)==ans) ++cnt,x=0;
}
if(cnt<k) ans^=1<<j;
}
for(int j=0;j<=30;j++)
{
if(yuy[j]==1)
ans|=1<<j;
else if(yuy[j]==0)
ans&=~(1<<j);
}
}
int main()
{
read(n),read(k);
for(int i=1;i<=n;i++) read(a[i]);
for(int j=0;j<=30;j++) yuy[j]=-1;
getans();
read(Q);
for(int op,x,i=1;i<=Q;i++)
{
read(op);
int flag=0;
if(op==1)
{
read(x);
for(int j=30;~j;j--)
if(x>>j&1)
{
if(yuy[j]==-1) flag=1;
yuy[j]=1;
}
if(flag) getans();
}
else if(op==2)
{
read(x);
for(int j=30;~j;j--)
if(!(x>>j&1))
{
if(yuy[j]==-1) flag=1;
yuy[j]=0;
}
if(flag) getans();
}
else
printf("%d\n",ans);
for(int j=0;j<=30;j++)
{
if(yuy[j]==1)
ans|=1<<j;
else if(yuy[j]==0)
ans&=~(1<<j);
}
}
return 0;
}

2019.5.4

牛客 某练习赛 Data Structure的更多相关文章

  1. 牛客网练习赛23 F 托米的游戏

    链接:https://www.nowcoder.com/acm/contest/156/F 来源:牛客网 题目描述 题目背景编不下去了 托米有一棵有根树 T, 树根为1,每轮他会在剩下的子树中等概率一 ...

  2. 牛客网练习赛28A

    题目链接:https://www.nowcoder.com/acm/contest/200/A 链接:https://www.nowcoder.com/acm/contest/200/A来源:牛客网 ...

  3. 牛客网练习赛18 A 【数论/整数划分得到乘积最大/快速乘】

    链接:https://www.nowcoder.com/acm/contest/110/A 来源:牛客网 题目描述 这题要你回答T个询问,给你一个正整数S,若有若干个正整数的和为S,则这若干的数的乘积 ...

  4. 牛客网练习赛26B(简单的dp)

    题目链接:https://www.nowcoder.com/acm/contest/180/B 链接:https://www.nowcoder.com/acm/contest/180/B来源:牛客网 ...

  5. 牛客网练习赛34-D-little w and Exchange(思维题)

    链接:https://ac.nowcoder.com/acm/contest/297/D 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...

  6. 牛客网练习赛25 C 再编号

    链接:https://www.nowcoder.com/acm/contest/158/C来源:牛客网 定义对 a 的再编号为 a' ,满足 . 现在有 m 次询问,每次给定 x,t ,表示询问经过 ...

  7. 牛客网练习赛t2(线段树)

    题解: 好像因为他说了 数据范围全部在ll以内 所以直接暴力就可以过了 比较正常是用线段树来维护 洛谷上有道模板题是支持加,乘,区间和 而这题还多了区间平方和的操作 按照那题的操作 我们维护的时候保证 ...

  8. 牛客网练习赛7-B-购物

    在遥远的东方,有一家糖果专卖店. 这家糖果店将会在每天出售一些糖果,它每天都会生产出m个糖果,第i天的第j个糖果价格为C[i][j]元. 现在的你想要在接下来的n天去糖果店进行选购,你每天可以买多个糖 ...

  9. 牛客网练习赛7-D-无向图(bfs,链式前向星)

    题意:中文题: 思路:就是找某个点距离其他点的距离,他给你很多点也无所谓.用一个dist[]数组,这个数组保存的是他给你的点到其他点的最短距离且标记的作用,然后bfs搜索就行了. 代码: #inclu ...

随机推荐

  1. QT blockingmaster例子学习

    dialog.h: #ifndef DIALOG_H #define DIALOG_H #include <QDialog> #include "masterthread.h&q ...

  2. Android学习--写一个发送短信的apk,注意布局文件的处理过程!!!

    刚开始写Android程序如图发现使用了findViewById方法之后输出的话居然是null(空指针错误),也就是说这个方法没有成功.网上说这样写是在activity_main .xml去找这个ID ...

  3. 埋在MySQL数据库应用中的17个关键问题

    出处:https://blog.csdn.net/weixin_42882439 MySQL的使用非常普遍,跟MySQL有关的话题也非常多,如性能优化.高可用性.强一致性.安全.备份.集群.横向扩展. ...

  4. PHP面试 MySQL创建高性能索引考点

    MySQL索引 MySQL索引的基础和类型 索引的基础:索引类似于书籍的目录,要想找到一本书的某个特定篇章,需要查找书的目录,定位对应的页码 存储引擎使用类似的方式进行数据查询,先去索引当中找到对应的 ...

  5. 8.Jmeter 快速入门教程 -- 如何使测试脚本更强大

    添加基本的elements例如Sampler 或者一些监听器,就可以完成基本的测试.但有时需要更复杂的测试场景,所以还有更多其他的元素.清看下表,了解各种单元组的用途.  可添加的单元组  用途 Sa ...

  6. layui 下拉框 动态获取数据

    $(function(){var grade=$("#grade");grade.append("一年级"); //添加下拉列表grade.append(&qu ...

  7. (4.20)sql server分离附加操作

    关键词:sql server分离.sql server附加.分离附加.sql server附加分离 [0].数据库分离.附加的说明 SQL Server提供了“分离/附加”数据库.“备份/还原”数据库 ...

  8. 一道面试题:js返回函数, 函数名后带多个括号的用法及join()的注意事项

    博客搬迁,给你带来的不便,敬请谅解! http://www.suanliutudousi.com/2017/11/13/js%E8%BF%94%E5%9B%9E%E5%87%BD%E6%95%B0%E ...

  9. Redis Sentinel 高可用方案

      redis 主从复制的问题 Redis主从复制可将主节点数据同步给从节点,从节点此时有两个作用: 1,一旦主节点宕机,从节点作为主节点的备份可以随时顶上来. 2,扩展主节点的读能力,分担主节点读压 ...

  10. Java原理领悟-JMM(java内存模型认知)

    总线锁.缓存锁.MESI缓存一致性协议.CPU 层面的内存屏障 1.JMM定义: Java Memory Model(java内存模型)是一系列的Java虚拟机平台对开发者提供的多线程环境下的内存可见 ...