博客
关于我
BZOJ 5443 [Ceoi2018]Lottery
阅读量:268 次
发布时间:2019-03-01

本文共 1052 字,大约阅读时间需要 3 分钟。

题目链接

题目大意

令两个序列为 k k -相似,当且仅当

k
为两个序列对应位置上不同的值的个数,例如1 2 3 41 3 3 3为2-相似,因为两个序列2位置与4位置是不同的。现有一个长度为 n n 的序列,可以将它划分为长度为
L
nL+1 n − L + 1 个子串。 Q Q 组询问,求每个子串与多少个其他子串为
k
i
相似。

Ln104,Q102 L ≤ n ≤ 10 4 , Q ≤ 10 2 ,空间32MB。

题解

考虑不卡空间的做法,令f[i][j]表示 i i 子串与其他子串有多少个

j
-相似的。转移时枚举两个子串开始位置的间隔,若开始位置+1,那么相似-原开始位置是不是相同的+新结束位置是不是相同的。最后前缀和求 j ≤ j 的和

现在考虑卡空间的做法,如果询问的是2,6,8,那么一个子串与另一个子串4-相似,实际上只会对询问6,8产生影响,离线存下所有询问,修改操作就直接找到第一个 它的询问,在询问上面修改,最后还是前缀和。

代码

#include 
#include
int read(){ int x=0,f=1; char ch=getchar(); while((ch<'0')||(ch>'9')) { if(ch=='-') { f=-f; } ch=getchar(); } while((ch>='0')&&(ch<='9')) { x=x*10+ch-'0'; ch=getchar(); } return x*f;}int print(int x){ if(x<0) { putchar('-'); x=-x; } if(x/10) { print(x/10); } putchar('0'+x%10); return 0;}const int maxn=10000;const int maxq=100;struct query{ int val,pre_id,ans_id; bool operator <(const query &other) const { return val

转载地址:http://abwo.baihongyu.com/

你可能感兴趣的文章
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>