C [yLOI2019] 棠梨煎雪

Background

岁岁花藻檐下共将棠梨煎雪

自总角至你我某日辗转天边

天淡天青 宿雨沾襟

一年一会信笺却只见寥寥数言

——银临《棠梨煎雪》

Description

给定 \(m\) 个长度为 \(n\) 的可能含有 的 01 串,其中 ? 既能代表 0 也能代表 1, \(q\) 次操作,每次给定一个区间,求有多少 01 串满足区间内的所有字符串都可以解释成该 01 串,或者单点修改某个字符串。

Limitations

Solution

子任务 \(1\):

输出 \(0\) 即可得分,期望得分 \(5~pts\)。

子任务 \(2\):

考虑 \(n\) 只有 \(10\),因此可以 \(O(2^n)\) 去枚举所有可能的串,然后对于每个询问 \(O(m)\) 的逐个判定是否合法。时间复杂度 \(O(qm2^n)\),期望得分 \(10~pts\)。

子任务 \(3\):

考虑对于一段所有字符串的第 \(x\) 个字符,一共有四种可能:确定为 \(0\);确定为 \(1\);都可以;都不可以。如果 \(0/1\) 都不可以,则答案为 \(0\),因为不会有任何一个字符串匹配该区间。如果确定为某个数,则这一位只有一种可能;否则这一位有两种可能。根据乘法原理,如果有 \(a\) 个位置有两种可能,则本次询问的答案为 \(2^a\)。

因此对于每个询问,\(O(nm)\) 地去遍历区间内所有字符即可。时间复杂度 \(O(nmq)\),期望得分 \(15~pts\)。

子任务 \(4\):

考虑 \(n\) 只有 \(30\),可以状压到 int 中。具体的,维护两个 int,第一个 int 维护对应位是否确定是 \(0\) 或 \(1\),第二个 int 维护如果确定是 01 了那么具体是 0 还是 1

例如,对于单个字符串,它所有的为 ? 的位置,在第一个 int 中对应位置是 0,所有为 01 的位置,在第在个 int 中对应的位置是 1,在第二个 int 中对应的位置是自身的值。

考虑 \(a_1,~a_2\) 是询问的左端点到某个字符串之前所维护的两个 int,\(b_1,~b_2\) 是该字符串的两个 int,现在合并这两个信息。

如果某一位置即不可以是 \(1\),也不可以是 \(0\),那么该字符串不为 ? 的位置在 \(b_2\) 中对应的值应该至少有一个和 \(a_2\) 中对应位置的值且 \(a_1\) 的该位置为 \(1\),位运算可以表现为 \((a1~\&~b_1)~\&~(a_2~\oplus~b_2) ~\neq 0\),则该询问的答案为 \(0\)。

否则这两段信息可以合并:将他们已经确定字符的位置合并起来,然后将确定位置对应的值合并起来即可。于是 \(a_1\) 对 \(b_1\) 取或, \(a_2\) 对 \(b_2\) 取或即可。

最终该询问 \(0/1\) 都可以的位置的个数即为 \(a_1\) 中 \(1\) 的个数。

时间复杂度 \(O(mq)\),期望得分 \(15~pts\)

子任务 \(5\):

由于 \(n\) 只有 \(1\),问题变成了求某个区间内的字符是不是全是 0,全是 1,全是 ?01 都有。可以考虑用线段树非常轻松的维护这样的信息。

时间复杂度 \(O(q \log m)\),期望得分 \(15~pts\)

子任务 \(6\):

世界上没有什么事情是开一棵线段树不能解决的,如果有,那就开 \(30\) 棵。

时间复杂度 \(O(nq \log m)\),期望得分 \(10~pts\)

子任务 \(7\):

考虑结合子任务 \(4\) 和子任务 \(5\) 的做法,发现两个区间的状压信息也可以用子任务 \(4\) 的方法合并。因此用线段树维护这两个 int 的状压信息即可。

时间复杂度 \(O(q \log m)\),期望得分 \(30~pts\)

【线段树】【P5522】[yLOI2019] 棠梨煎雪的更多相关文章

  1. P5522 [yLOI2019] 棠梨煎雪

    updata on 2020.3.19 今天把博客从洛谷往博客园搬,图炸了 其实早就发现了,懒得管 那图其实就是一个用dev自带的调试功能调试时,RE了的报错 当时觉得很奇怪看不出是啥,现在再看已经觉 ...

  2. 洛谷P5522 【[yLOI2019] 棠梨煎雪】

    区间操作考虑用线段树维护. 建\(n*2\)棵线段树,前\(n\)棵线段树维护每个串的第i位是否是0. 后\(n\)棵线段树维护每个串的第i位是否是1. 如果是问号的话,直接跳过就好(通过1和0能看出 ...

  3. 【6.24校内test】T3 棠梨煎雪

    [题目背景] 岁岁花藻檐下共将棠梨煎雪. 自总角至你我某日辗转天边. 天淡天青,宿雨沾襟. 一年一会信笺却只见寥寥数言. ——银临<棠梨煎雪> [问题描述] 扶苏正在听<棠梨煎雪&g ...

  4. 6.25考试整理:江城唱晚&&不老梦&&棠梨煎雪——题解

    按照旧例,先安利一下主要作者:一扶苏一 以及扶苏一直挂念的——银临姐姐:银临_百度百科 (滑稽) 好哒,现在步入正题: 先看第一题: 题解: 在NOIP范围内,看到“求方案数”,就说明这个题是一个计数 ...

  5. Bzoj[Usaco2018 Feb]5194 Snow Boots(线段树)

    Description 到冬天了,这意味着下雪了!从农舍到牛棚的路上有N块地砖,方便起见编号为1…N,第i块地砖上积了fi英尺的雪 .在Farmer John的农舍的地窖中,总共有B双靴子,编号为1… ...

  6. 【BZOJ 4662】 4662: Snow (线段树+并查集)

    4662: Snow Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 136  Solved: 47 Description 2333年的某一天,临冬突 ...

  7. BZOJ5194: [Usaco2018 Feb]Snow Boots(排序&set)(可线段树优化)

    5194: [Usaco2018 Feb]Snow Boots Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 102  Solved: 79[Subm ...

  8. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  9. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

随机推荐

  1. 使用SonarQube和SonarQube Scanner分析项目

    一.概述 SonarQube的安装,请参考链接:https://www.cnblogs.com/xiao987334176/p/12011623.html 配置好sonar的服务端后,接下来就要使用s ...

  2. MySQL使用现状分析与优化

    前言 再紧张的裁员氛围,也不该影响你学习的心态.不要本末倒置,技术永远不会落后,只要你还在学习的道路上,没有后退. 数据库架构 目前生产环境RDS是多区可用架构.数据库实例发生计划内或计划外的中断时, ...

  3. file 从InputStream读取byte[]示例

    file 从InputStream读取byte[]示例 分类专栏: java基础   public static byte[] getStreamBytes(InputStream is) throw ...

  4. IEEE浮点表示 (原发布 csdn 2018-10-14 10:29:33)

    目录 观察IEEE浮点表示 工作中遇到过整型转浮点型(union那种转换),碰到就看下书,过后就遗忘了.等过段时间又出现此现象,又重新拿起书本,这次记录了过程.然而一直等到今天才写出来,以防以后还用到 ...

  5. 15、VUEX-Store

    1.什么是VUEX Vuex是管理vue的组件状态的工具. 个人理解:vuex是管理组件之间通信的一个插件. 2.为什么要用VUEX 我们知道组件之间是独立的,组件之间想要实现通信,我目前知道的就只有 ...

  6. eclipse自定义导入或者编写版本格式化 xml

    1.自定义或者自己导入版本格式 window——preferences——java——Code style ——formatter(New 或者 import)

  7. <compilation debug="true" targetFramework="4.5.2"> 报错解决方案

    有的时候新建项目,默认会选择比较高的 .net framework 版本如 4.5.2 有的时候发布项目就会遇到这个问题 解决的话 改成4.0就行了! 看你发布在哪里,如果在本地或者服务器,只要去下载 ...

  8. NetCoreApi框架搭建(二、Nlog使用配置)

    本文只配置了简单文件存储 1.添加nuget包 2.添加日志配置文件nlog.config 这里配置了三个target区分不同的日志,具体配置需要自己研究,推荐链接https://www.cnblog ...

  9. webapi 集成NLog

    参考项目代码:SwaggerDemoApi 安装 打开nuget管理器--->搜索nlog,安装箭头所指的两个文件到你的项目中,config安装到你的API项目即可,nlog文件安装到你用得到n ...

  10. SpringIOC源码解析(下)

    注意,看完这篇文章需要很长很长很长时间... 本篇文章是SpringIOC源码解析(上)的续集,上一篇文章介绍了使用XML的方式启动Spring,然后追踪了BeanFactory容器的创建.配置文件的 ...