Interesting Array

题目大意

构造一个序列 \(a\),使其满足若干限制条件,每个限制条件是形如 l r q 的式子,其意义是:\(\&_{i=l}^ra_i=q\)。

题意分析

看上去是构造题,实际上是数据结构题。

我们不妨先令初始时 \(a\) 为一个全 \(0\) 序列,再逐一看每个限制条件。

为了满足某一个限制条件 \(l,r,p\),\([l,r]\) 区间的数必须符合以下两点:

  • \(1\),在二进制表示中,\(p\) 为 \(1\) 的位置均为 \(1\)。
  • \(2\),在二进制表示中,\(p\) 为 \(0\) 的位置区间内至少有一个数该位为 \(0\)。

我们发现,同时构造出满足两个条件的序列比较麻烦,且不好判断无解,因此,我们可以让一个条件成为构造的依据,另一个条件成为判断的依据。

具体的说,我们只需要构造出满足其中一个条件的序列,再逐一判断每个区间是否满足另一个条件即可。

因此,我们不妨先构造一个满足条件 \(1\) 的序列,再逐一对条件 \(2\) 进行判断。

那么,现在问题就变成了如果构造一个满足条件 \(1\) 的序列和如何对条件 \(2\) 进行判断。

这其实很简单,我们只需要用线段树进行区间按位或和区间求按位与就行了。

这是因为为了满足条件 \(1\),我们需要让区间的二进制表示包含 \(p\),这等价于于区间按位或 \(p\),而条件 \(2\) 与区间的按位与是 \(p\) 二者也等价。

综上,我们只需要维护一颗线段树,支持区间或和区间求与即可。

代码

#include <bits/stdc++.h>
using namespace std;
const int N=100100; int n,m,inp[N][3]; struct STn{int l,r,t,sum;};//sum表示区间与的结果,t是懒标记
struct ST{
STn a[N<<2];
void or_t(int p,int k){
a[p].t|=k;a[p].sum|=k;//都或上k
}
void push_down(int p){//下放懒标记
if(a[p].t){
or_t(p<<1,a[p].t);
or_t(p<<1|1,a[p].t);
a[p].t=0;
}
}
void build(int p,int l,int r){//简单建树
a[p].l=l;a[p].r=r;a[p].t=0;
if(a[p].l==a[p].r) return ;
int mid=(a[p].l+a[p].r)>>1;
build(p<<1,l,mid);
build(p<<1|1,mid+1,r);
}
void or_all(int p,int l,int r,int k){//区间或
if(l<=a[p].l&&a[p].r<=r){or_t(p,k);return ;}
push_down(p);int mid=(a[p].l+a[p].r)>>1;
if(l<=mid) or_all(p<<1,l,r,k);
if(r>mid) or_all(p<<1|1,l,r,k);
a[p].sum=a[p<<1].sum&a[p<<1|1].sum;
}
int and_all(int p,int l,int r){//区间求与
if(l<=a[p].l&&a[p].r<=r) return a[p].sum;
push_down(p);int mid=(a[p].l+a[p].r)>>1;
if(r<=mid) return and_all(p<<1,l,r);
if(l>mid) return and_all(p<<1|1,l,r);
return and_all(p<<1,l,r)&and_all(p<<1|1,l,r);
}
void print(int p){//输出序列
if(a[p].l==a[p].r){cout<<a[p].sum<<' ';return ;}
push_down(p);int mid=(a[p].l+a[p].r)>>1;
print(p<<1);print(p<<1|1);
}
}tree; int main(){
scanf("%d%d",&n,&m);
tree.build(1,1,n);
for(int i=1;i<=m;i++){
scanf("%d%d%d",&inp[i][0],&inp[i][1],&inp[i][2]);
tree.or_all(1,inp[i][0],inp[i][1],inp[i][2]);
}
for(int i=1;i<=m;i++)
if(tree.and_all(1,inp[i][0],inp[i][1])!=inp[i][2]){cout<<"NO\n";return 0;}
cout<<"YES\n";
tree.print(1);
return 0;
}

Interesting Array 题解的更多相关文章

  1. B. Interesting Array(线段树)

    B. Interesting Array time limit per test 1 second memory limit per test 256 megabytes input standard ...

  2. Codeforces 482B Interesting Array(线段树)

    题目链接:Codeforces 482B Interesting Array 题目大意:给定一个长度为N的数组,如今有M个限制,每一个限制有l,r,q,表示从a[l]~a[r]取且后的数一定为q,问是 ...

  3. codeforces 482B. Interesting Array【线段树区间更新】

    题目:codeforces 482B. Interesting Array 题意:给你一个值n和m中操作,每种操作就是三个数 l ,r,val. 就是区间l---r上的与的值为val,最后问你原来的数 ...

  4. Codeforces 482B Interesting Array(线段树区间更新)

    题目链接 Interesting Array 区间更新.然后对于每一个约数重新求一遍区间的&值,不符合就跳出. #include <bits/stdc++.h> using nam ...

  5. Codeforces E. Interesting Array(线段树)

    题目描述: D. Interesting Arraytime limit per test1 secondmemory limit per test256 megabytesinputstandard ...

  6. [LeetCode]Remove Duplicates from Sorted Array题解

    Remove Duplicates from Sorted Array: Given a sorted array, remove the duplicates in place such that ...

  7. Leetcode Find Minimum in Rotated Sorted Array 题解

    Leetcode Find Minimum in Rotated Sorted Array 题目大意: 对一个有序数组翻转, 就是随机取前K个数,移动到数组的后面,然后让你找出最小的那个数.注意,K有 ...

  8. [CF482B]Interesting Array

    题目大意:构造一个序列$S$,有$m$条限制,每条为$l\;r\;q$,表示$\&_{i=l}^r S_i=q$ 题解:每条限制就把$[l,r]$内的数或上$q$,最后判断就行了 卡点:我又写 ...

  9. Codeforces Round #275 Div.1 B Interesting Array --线段树

    题意: 构造一个序列,满足m个形如:[l,r,c] 的条件. [l,r,c]表示[l,r]中的元素按位与(&)的和为c. 解法: 线段树维护,sum[rt]表示要满足到现在为止的条件时该子树的 ...

  10. Codeforces 482B Interesting Array

    题意:构造一个长度为n的序列,使其满足m个形式如下如下约束:a[l]&a[l+1]&a[l+2]&....&a[r]=q 从Dalao的博客上看到这题,决定去水水.做法 ...

随机推荐

  1. 【HTML】Echart图表

    layui-echarts 简介 基于layui 实现的 echart 图表 Echart 官网 示例 Echart示例 下载Echart Echart下载 我们选择最下面的在线定制 我这里就按照它默 ...

  2. 前端Vuer,请收好这份《Vue组件单元测试》宝典,给自己多一些安全感

    大家好,我是 Kagol. 作为一名前端,在做业务开发的过程中,你是否曾经: 因为担心上线之后出bug,而反复手工验证自己负责的模块 不敢修改现有的"屎山"(别人写的或者是自己1年 ...

  3. Unity UGUI的VerticalLayoutGroup(垂直布局)组件的介绍及使用

    Unity UGUI的VerticalLayoutGroup(垂直布局)组件的介绍及使用 1. 什么是VerticalLayoutGroup组件? VerticalLayoutGroup是Unity ...

  4. vue项目node_modules文件过大问题

    node_modules目录下.cache下最大文件删除即可(vue-loader)

  5. pandas 缺失值与空值处理

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/lwgkzl/article/detail ...

  6. mysql根据mysqlbinlog恢复找回被删除的数据库

    年初和朋友一起做了个项目,到现在还没收到钱呢,今天中午时候突然听说之前的数据库被攻击了,业务数据库全部被删除.看有没有什么办法恢复,要是恢复不了,肯定也别想拿钱了吧? README FOR RECOV ...

  7. 搜索(DFS/BFS)

    广度优先搜索(BFS) 基本要点: - 利用队列(先进先出) - 一层一层搜索 - 适合于连通块的搜索 - 任何的BFS都可以转化为对树的广搜 基本流程: - 选择搜索的起点,起点入队,起点标记为已访 ...

  8. ros源的移除

    在Ubuntu上卸载了ros系统后,每次运行源更新命令 sudo apt update 都会报错,提示ros源找不到等问题. 这时,只需要 cd /etc/apt/souce.list.d sudo ...

  9. GC的前置工作,聊聊GC是如何快速枚举根节点的

    本文已收录至GitHub,推荐阅读 Java随想录 微信公众号:Java随想录 原创不易,注重版权.转载请注明原作者和原文链接 目录 什么是根节点枚举 根节点枚举存在的问题 如何解决根节点枚举的问题 ...

  10. 知识图谱(Knowledge Graph)- Neo4j 5.10.0 使用 - Java SpringBoot 操作 Neo4j

    上一篇使用了 CQL 实现了太极拳传承谱,这次使用JAVA SpringBoot 实现,只演示获取信息,源码连接在文章最后 三要素 在知识图谱中,通过三元组 <实体 × 关系 × 属性> ...