CF1849
氵
在吃了五次罚时后,我终于放弃了卡常优先队列,并发现:把余 \(0\) 看作余 \(k\),答案就是余数从大到小排列的,每种余数内部又按照下标排序。
我为什么没想到哈希?自我检讨:见到关于字符串判定相等/不同个数时,一定要尝试用哈希!!!
记前缀 \([0,i)\) 的哈希值为 \(f_i\),全为 \(1\) 的前缀 \([0,i)\) 的哈希值为 \(g_i\),\([0,i)\) 中 \(1\) 的个数为 \(h_i\)。
设排序的区间为 \([l,r)\),则新哈希值为 \(f_n-f_r+f_l+g_r-g_{[r-(h_r-h_l)]}\)。
用 std::set 维护即可。
非哈希做法:
对每个位置求出它左边(包括它)的第一个 0 和右边(包括它)的第一个 1。存在两个数组 \(lf,rg\) 里面。
对于一个修改区间 \([l,r]\),它真实改动的部分其实是 \([rg_l,lf_r]\)。如果这两个元素设定为不存在,那么就没有修改。
把每对 \((rg_l,lf_r)\) 用 set 维护。
贪心法:先有一个错误但是有启发性的贪心:先把所有 \(2\) 涂黑,然后标记所有 \(2\) 边上的,再把剩下的涂黑。
这是错的,比如 0 2 1 2 0,把第一个 \(2\) 涂黑之后可以传递过去。
于是想到把一段连续非 0 的数合并为一个块。 这一段只需要一个硬币。
如果一个块内有 \(2\),这个块左右两边的两个都能被涂黑;如果只有 \(1\),那只有一个能被涂黑。
模拟即可。
dp 法:
\(dp_i\) 表示涂黑前 \(i\) 个的最小硬币数。
基本的,\(dp_{i+1}=\min(dp_{i+1},dp_i+1).\)
若 \(a[i+1]=1\),\(dp_{i+2}=\min(dp_{i+2},dp_{i}+1)\)。
若 \(a[i+2]=1\),\(dp_{i+2}=\min(dp_{i+2},dp_{i}+1)\)。
若 \(a[i+1]=1\),\(dp_{i+2}=\min(dp_{i+1},dp_{i}+1)\)。
若 \(a[i+1]=2\),\(dp_{i+2}=\min(dp_{i+2},dp_{i}+1)\)。
若 \(a[i+2]=2\),\(dp_{i+2}=\min(dp_{i+3},dp_{i}+1)\)。
答案为 \(\min(dp_n,dp_{n+1}).\)
朴实无华的题面:有多少个区间最大值在最小值右边。
先单调栈求出每个数左右两边第一个比他大/小的位置。
记 \(a_i\) 左边第一个比它大的位置是 \(l_i\),右边第一个比它大的位置是 \(r_i\),左边第一个比他小的位置 \(s_i\),右边第一个比它小的位置 \(t_i\)。
按套路,枚举每个 \(a_i\) 作为区间的最大值。
有两种方法计算这种区间的个数:
枚举 \(j:l_i\le j<i\),求出 \(j\sim i-1\) 的最小值 \(p\),要求在这个区间内 \(i\) 的右边不允许有比 \(p\) 小的。(否则最大值 \(i\) 就在最小值左边)即右端点 \(\ge t_p\) 就不合法,总个数减去不合法个数。
枚举 \(j:i<j\le r_i\),求出 \(i+1\sim j\) 的最小值 \(p\)。同理,只要左端点 \(\le s_p\) 就合法。
注意以上两种方法都需单独考虑 \(i=j\) 的情况。
我们枚举 \(a_i\) 时,根据 \(i-l_i,r_i-i\) 的大小选择复杂度较低的方法。便可通过此题。
但是感觉时间复杂度不太对啊?
如果按最大值从大到小枚举,每次在循环 \(x\) 时如果是重复循环,区间长度至多是上一次循环 \(x\) 时的一半。
为什么呢?假设上一次循环 \(x\) 时是枚举到 \(a_i\),这次是 \(a_j\)。(不妨 \(x\) 是左端点)
显然应该 \(j<i\),不然因为我们从大到小枚举,有 \(a_i>a_j\),那枚举 \(a_j\) 的左端点不应该枚举到 \(x\),因为此时 \(x\) 在 \(i\) 的左边,违反了上面的方法。
那么就有 \(x<j<i\),注意因为从大到小,所以 \(r_j\le i\)。
我们选择了用枚举左端点的方法,说明 \(j-l_j\le r_j-j\le i-j\).
那也就说明 \(j\) 这个位置应该在 \([l_j,i]\) 的左半部分,而 \(x\in [l_j,j]\),上次 \(x\) 被枚举到是和 \(i\) 一起,显然应该有 \(j-x\le \dfrac{i-x}{2}\).
那每个数被枚举到,区间长度至少除以 \(2\),因此复杂度 \(O(n\log n)\).
随机推荐
- VirtualBox 设置开机自动在后台启动虚拟机
打开 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp 新建文件 virtualbox.bat 编写脚本 "C:\Pr ...
- NLP复习之神经网络
NLP复习之神经网络 前言 tips: 设计神经网络时,输入层与输出层节点数往往固定,中间层可以自由指定: 神经网络中的拓扑与箭头代表预测过程数据流向,与训练的数据流有一定区别: 我们不妨重点关注连接 ...
- 解决在Edge浏览器中使用不了(找不到)new bing的情况
1.问题 我们有时候看不到下图圈出部分的信息,无法找到New Bing的入口(这边是空的) 2.解决方式 1.选择右上角的三条杠,并选择其中的settings 2.将其中的country一项改为外国即 ...
- Linux-分区-fdisk-mkfs-mount
- [转帖]聊聊字符串数据长度和nls_length_semantics参数
字符串是我们设计数据库经常用到的类型,从传统的ASCII格式到UTF-8格式,不同应用需求对应不同的字符类型和长度配置.针对Oracle而言,最常用的类型无外乎char和varchar2两个基本类型. ...
- [转帖]top指令如何查询指定用户的所有进程?
有两种方法. 1.top指令与字符串查询指令通过通道配合查询. 指令: "-d 5"指的是每五秒刷新一次进程列表,"grep"是字符串查询指令,它可以将含 ...
- [转帖] Linux命令拾遗-文本处理篇
https://www.cnblogs.com/codelogs/p/16060413.html 简介# 这是Linux命令拾遗系列的第二篇,本篇主要介绍Linux中与文本处理相关的命令,如xargs ...
- 龙芯中标麒麟 上面安装libgdiplus的方法
其实方法与之前的blog 基本上完全一样 但是发现有一个问题 安装完libgdiplus之后必须重启一下才能有效果... CentOS 安装libgdi的方法 1. 安装必须的包 1 yum ins ...
- ESXi重置密码以及修改网络IP地址的方法
Study From https://www.cnblogs.com/mk21/p/15784082.html 前期公司有部分虚拟化的服务器因为只通过vCenter进行管理. 导致密码遗失. 最近因为 ...
- redis 6源码解析之 ziplist
ziplist ziplist结构 ziplist的布局如下,所有的字符默认使用小端序保存: +--------+--------+--------+--------+-------+-------+ ...