UOJ#172. 【WC2016】论战捆竹竿
传送门
首先这个题目显然就是先求出所有的 \(border\),问题转化成一个可行性背包的问题
一个方法就是同余类最短路,裸跑 \(30\) 分,加优化 \(50\) 分
首先有个性质
\(border\) 分成的等差数列的个数不超过 \(log\)
和回文树的性质的证明类似瞎画图一下就行了
我们注意到可以一个一个等差数列的更新最短路
要做到这个,必须能从之前的等差数列的模数 \(n\) 转移到当前等差数列的 \(x\)
假设模 \(n\) 的最短路为 \(f\),模 \(x\) 的为 \(g\)
只需要 \(f_i\) 更新 \(g_{f_i~mod~x}\) 之后 \(g\) 自己通过添加 \(n\) 更新即可
现在考虑 \(g\) 每次 \(+n\) 更新
注意到把每次 \(+n\) 的下标弄出来,一定是若干个环,环之间独立
显然每个的最小值不会再次更新,那么找到这个点就变成了链,然后一个个向后 \(+n\) 更新即可
再考虑每个等差数列的内部更新,模数我们选择首项 \(x\),这样才比较可做
设公差为 \(d\),长度为 \(len\)
同样的,把每次 \(+d\) 的下标弄出来,还是若干个独立的环
找到最小值的位置编号 \(0\) 对变成的链向后一一编号
那么对于第 \(i\) 个点,可以从 \(j\) 加上 \(x+d\times(i-j)\) 转移,这样的 \(j\) 必须满足 \(i-j<len\)
这个东西显然可以单调队列优化一波
然后就可能可以通过这一题了
关于被hack这件事情,卡卡常就好了
# include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn(5e5 + 5);
int test, n, nxt[maxn], len[maxn], cnt, vis[maxn], idx, id[maxn];
ll w, ans, f[maxn], g[maxn], inf, que[maxn];
char s[maxn];
queue <int> q;
inline void Calc(int lst, int u, int d, int num) {
int i, j, k, mnp, hd, tl;
for (i = 0; i < lst; ++i) g[i] = f[i];
for (i = 0; i < u; ++i) f[i] = inf;
for (i = 0; i < lst; ++i) if (g[i] != inf) f[g[i] % u] = min(f[g[i] % u], g[i]);
++idx;
for (i = 0; i < u; ++i)
if (vis[i] != idx) {
mnp = i, vis[i] = idx;
for (j = (i + lst) % u; j ^ i; j = (j + lst) % u) {
if (f[j] < f[mnp]) mnp = j;
vis[j] = idx;
}
for (k = mnp, j = (mnp + lst) % u; j ^ mnp; k = j, j = (j + lst) % u)
f[j] = min(f[j], f[k] + lst);
}
++idx;
for (i = 0; i < u; ++i)
if (vis[i] != idx) {
mnp = i, vis[i] = idx, hd = 0, tl = -1;
for (j = (i + d) % u; j ^ i; j = (j + d) % u) {
if (f[j] < f[mnp]) mnp = j;
vis[j] = idx;
}
que[0] = f[mnp], id[++tl] = 0;
for (k = 1, j = (mnp + d) % u; j ^ mnp; j = (j + d) % u, ++k) {
while (hd <= tl && k - id[hd] >= num) ++hd;
if (hd <= tl) f[j] = min(f[j], que[hd] + u + (ll)(k - id[hd]) * d);
while (hd <= tl && que[tl] - (ll)id[tl] * d > f[j] - (ll)k * d) --tl;
que[++tl] = f[j], id[tl] = k;
}
}
}
inline void Solve() {
int i, j, u, d, lst;
scanf("%d%lld", &n, &w), ans = 0;
scanf(" %s", s + 1);
for (i = 2, j = 0; i <= n; ++i) {
while (j && s[i] != s[j + 1]) j = nxt[j];
j += s[i] == s[j + 1], nxt[i] = j;
}
cnt = 0, j = n;
while (j) len[++cnt] = n - nxt[j], j = nxt[j];
sort(len + 1, len + cnt + 1), --cnt;
memset(f, 63, sizeof(f)), inf = f[0];
f[n % len[1]] = n, u = lst = n;
reverse(len + 1, len + cnt + 1);
for (i = 1; i < cnt; i = j) {
d = len[i] - len[i + 1], j = i + 1;
while (j <= cnt && len[j - 1] - len[j] == d) ++j;
u = len[j - 1], Calc(lst, u, d, j - i), lst = u;
}
if (cnt) u = len[cnt], Calc(lst, u, 0, 1);
for (i = 0; i < u; ++i) if (f[i] <= w) ans += (w - f[i]) / u + 1;
printf("%lld\n", ans);
}
int main() {
scanf("%d", &test);
while (test) --test, Solve();
return 0;
}
UOJ#172. 【WC2016】论战捆竹竿的更多相关文章
- bzoj4406: [Wc2016]论战捆竹竿&&uoj#172. 【WC2016】论战捆竹竿
第二次在bzoj跑进前十竟然是因为在UOJ卡常致死 首先这个题其实就是一个无限背包 一般做法是同余最短路,就是bzoj2118: 墨墨的等式可以拿到30分的好成绩 背包是个卷积就分治FFT优化那么下面 ...
- luogu P4156 [WC2016]论战捆竹竿
传送门 官方题解(证明都在这) 神仙题鸭qwq 转化模型,发现这题本质就是一个集合,每次可以加上集合里的数,问可以拼出多少不同的数 首先暴力需要膜意义下的最短路,例题戳这 然后这个暴力可以优化成N^2 ...
- Luogu4156 WC2016 论战捆竹竿 KMP、同余类最短路、背包、单调队列
传送门 豪华升级版同余类最短路-- 官方题解 主要写几个小trick: \(1.O(nm)\)实现同余类最短路: 设某一条边长度为\(x\),那么我们选择一个点,在同余类上不断跳\(x\),可以形成一 ...
- BZOJ4406 WC2016 论战捆竹竿
Problem BZOJ Solution 显然是一个同余系最短路问题,转移方案就是所有|S|-border的长度,有 \(O(n)\) 种,暴力跑dijkstra的复杂度为 \(O(n^2\log ...
- 「WC2016」论战捆竹竿
「WC2016」论战捆竹竿 前置知识 参考资料:<论战捆竹竿解题报告-王鉴浩>,<字符串算法选讲-金策>. Border&Period 若前缀 \(pre(s,x)\ ...
- UOJ#172. 【WC2016】论战捆竹竿 字符串 KMP 动态规划 单调队列 背包
原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ172.html 题解 首先,这个问题显然是个背包问题. 然后,可以证明:一个字符串的 border 长度可 ...
- 【WC2016】论战捆竹竿
已经快三周了啊--终于把挖的坑填了-- 首先显然是把除了自身的所有border拿出来,即做 \(\left\{ n - b_1, n - b_2, \dots, n - b_k, n \right\} ...
- 【LuoguP4156】论战捆竹竿
题目链接 题意简述 你有一个长度为 n 的字符串 , 将它复制任意次 , 复制出的串的前缀可以与之前的串的后缀重叠在一起 , 问最后总共可能的长度数目 , 长度不能超过 \(w\) 多组数据. \(n ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
随机推荐
- Dreamweaver_CS6安装及破解文件
资源下载地址: 链接: https://pan.baidu.com/s/1mhQ5DoO 密码: mnv3 1.下载,安装,先作为试用版安装 可能显示的页面不一样,但是就是安装试用版 2.接受许可协议 ...
- SaltStack Pillar 详解
简介 grains用于存储静态不易变更的数据,而pillar一般用于存储动态, 敏感的数据,通过minion和master设置或获取grains信息,而pillar信息只能在master端配置,在到m ...
- 50.RocketMQ (quickstart)
要多给下属表功,绝不能抢功. 1.订阅消息 /** * Copyright (C) 2010-2013 Alibaba Group Holding Limited * * Licensed under ...
- SVN服务器端环境搭建步骤
5.1 安装服务器端程序 yum install -y subversion 5.2 创建并配置版本库 创建版本库目录 mkdir -p /var/svn/repository 在版本库目录下创建具体 ...
- 直接线性变换解法(DLT)用于标定相机
直接线性变换法是建立像点坐标和相应物点物方空间坐标之间直接的线性关系的算法.特点:不需要内外方位元素:适合于非量测相机:满足中.低精度的测量任务:可以标定单个相机. 1 各坐标系之间的关系推导直接线性 ...
- java 实用Util汇总
1.Util介绍 Util是工具的意思,一般来说,常常用来描述和业务逻辑没有关系的数据处理. Util一般要和私有方法对比:私有方法一般来说是只是在特地场景下使用的,私有方法越多,代码结构越乱.常见的 ...
- elasticsearch 基础笔记
基础: 1.查看 所有节点,及版本 http://192.168.18.7:9200/_nodes/_all/version?pretty=true
- xampp使用技巧及问题汇总
1)在win7上同时装有IIS 和 xampp1.8.2 ,会出现Apache启动时,提示80端口被占用的情况(一般是iis安装之后出现的常见情况). 情况1: xampp 在启动时会检测Apach ...
- centos安装图形操作界面
yum groupinstall "GNOME Desktop" "Graphical Administration Tools"
- VS2015 MSVCRTD.lib(_chandler4gs_.obj) : error LNK2019: unresolved external symbol __except_handler4_common referenced in function __except_handler4
今天在VS2015中用编译好的QT5静态库打包软件,配置好QT的静态环境后, 发现报MSVCRTD.lib(_chandler4gs_.obj) : error LNK2019: unresolved ...