HDU 3086 马拉车模板
模板,但是对这个算法还是不太清楚,真实不明觉厉....
#include <iostream>
#include <cstdio>
#include <string.h>
#pragma warning ( disable : 4996 )
using namespace std; inline int Max(int a,int b) { return a>b?a:b; }
inline int Min(int a,int b) { return a>b?b:a; }
const int inf = 0x3f3f3f3f;
const int maxn = 1e5+1e4+; char str[maxn];
char nstr[maxn<<];
int maxlen[maxn<<];
int len, plen, ans; void init()
{
memset( nstr, , sizeof(nstr) );
memset( maxlen, , sizeof(maxlen) );
len = strlen(str);
nstr[] = '$'; nstr[] = '#'; int j = ;
for ( int i = ; i < len; i++ )
{
nstr[j++] = str[i];
nstr[j++] = '#';
}
nstr[j] = '\0';
plen = j;
} void solve()
{
ans = -;
int id, mx = ; for ( int i = ; i < plen; i++ )
{
if( i < mx )
maxlen[i] = Min( maxlen[*id-i], mx-i );
else
maxlen[i] = ; while( nstr[i-maxlen[i]] == nstr[i+maxlen[i]] )
maxlen[i]++; if ( mx < i + maxlen[i] )
{
id = i;
mx = i + maxlen[i];
}
ans = Max(ans, maxlen[i]-);
}
} int main()
{
while ( ~scanf("%s", str) )
{
init();
solve();
printf( "%d\n", ans );
}
return ;
}
又做了一道几乎模板的题(吉哥系列故事——完美队形II),终于对马拉车有点理解了,这算法实在太巧妙了!
和模板几乎一样,只不过增多了个左半边要升序排列罢了
#include <iostream>
#include <cstdio>
#include <string.h>
#pragma warning ( disable : 4996 )
using namespace std; inline int Max(int a,int b) { return a>b?a:b; }
inline int Min(int a,int b) { return a>b?b:a; }
const int inf = 0x3f3f3f3f;
const int maxn = 1e5+; int maxl[maxn<<];
int str[maxn], nstr[maxn<<];
int N, ans, plen; void init()
{
memset( maxl, , sizeof(maxl) );
memset( nstr, , sizeof(nstr) );
nstr[] = ; nstr[] = -; int j = ;
for( int i = ; i < N; i++ )
{ nstr[j++] = str[i]; nstr[j++] = -; }
nstr[j] = -;
plen = j;
} void solve()
{
ans = -;
int id, mx = ;
for ( int i = ; i < plen; i++ )
{
if(i < mx)
maxl[i] = Min(maxl[*id-i], mx-i);
else
maxl[i] = ; while( nstr[i-maxl[i]]==nstr[i+maxl[i]] && nstr[i-maxl[i]]<=nstr[i-maxl[i]+] )
maxl[i]++;
if(mx < i + maxl[i])
{ id = i; mx = i + maxl[i]; } ans = Max(ans, maxl[i]-);
}
} int main()
{
int all; cin >> all;
while (all--)
{
cin >> N;
for( int i = ; i < N; i++ )
scanf( "%d", &str[i] );
init();
solve(); printf( "%d\n", ans );
}
return ;
}
HDU 3086 马拉车模板的更多相关文章
- hdu 3068 最长回文子串 马拉车模板
前几天用后缀数组写过一次这题,毫无疑问很感人的TLE了-_-|| 今天偶然发现了马拉车模板,O(N)时间就搞定 reference:http://acm.uestc.edu.cn/bbs/read.p ...
- hdu 1686 KMP模板
// hdu 1686 KMP模板 // 没啥好说的,KMP裸题,这里是MP模板 #include <cstdio> #include <iostream> #include ...
- HDU 2138 Miller-Rabin 模板题
求素数个数. /** @Date : 2017-09-18 23:05:15 * @FileName: HDU 2138 miller-rabin 模板.cpp * @Platform: Window ...
- hdu 1348 凸包模板
http://acm.hdu.edu.cn/showproblem.php?pid=1348 造城墙问题,求出凸包加上一圈圆的周长即可 凸包模板题 #include <cstdio> #i ...
- hdu3068 最长回文 马拉车模板题
题目传送门 马拉车算法模板题. 学习博客 #include<bits/stdc++.h> #define clr(a,b) memset(a,b,sizeof(a)) using name ...
- HDU 1392 凸包模板题,求凸包周长
1.HDU 1392 Surround the Trees 2.题意:就是求凸包周长 3.总结:第一次做计算几何,没办法,还是看了大牛的博客 #include<iostream> #inc ...
- HDU 2586 (LCA模板题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2586 题目大意:在一个无向树上,求一条链权和. 解题思路: 0 | 1 / \ 2 3 ...
- HDU 2082 母函数模板题
找单词 Time Limit: 1000MS Memory Limit: 32768KB 64bit IO Format: %I64d & %I64u Submit Status De ...
- HDU 2255 & KM模板
题意: 一张完备二分图求最优完备匹配. SOL: 这题就不讲什么sol了...毕竟是裸的KM,不会的话可以看老人家的大白鼠,一些问题看代码注释.讲讲经历(悲惨的经历) 刚打完,自信地交上去发现MLE. ...
随机推荐
- Java A*算法搜索无向图最短路径
网上看了很多别人写的A*算法,都是针对栅格数据进行处理,每次向外扩展都是直接八方向或者四方向,这样利于理解.每次移动当前点,gCost也可以直接设置成横向10斜向14. 但是当我想处理一个连续的数据集 ...
- java笔试之参数解析(正则匹配)
在命令行输入如下命令: xcopy /s c:\ d:\, 各个参数如下: 参数1:命令字xcopy 参数2:字符串/s 参数3:字符串c:\ 参数4: 字符串d:\ 请编写一个参数解析程序,实现将命 ...
- UMP系统功能 资源调度
- JS流程控制语句 二选一 (if...else语句) 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时执行的代码}
二选一 (if...else语句) if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码. 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时 ...
- 解决Mysql因内存不足启动失败的问题
参考:https://www.jb51.net/article/136432.htm 一.查看内存 free -h free -m 二.解决方法: 1.增加swap交换空间解决问题: dd if=/d ...
- 纵览轻量化卷积神经网络:SqueezeNet、MobileNet、ShuffleNet、Xception
近年提出的四个轻量化模型进行学习和对比,四个模型分别是:SqueezeNet.MobileNet.ShuffleNet.Xception. SqueezeNet https://arxiv.org/p ...
- token 与 基于JWT的Token认证
支持跨域访问,无状态认证 token特点 支持跨域访问: Cookie是不允许垮域访问的,这一点对Token机制是不存在的,前提是传输的用户认证信息通过HTTP头传输 无状态(也称:服务端可扩展行): ...
- 并发和多线程(九)--AbstractQueuedSynchronizer排他锁基本原理
AbstractQueuedSynchronizer简称为AQS,AQS是ReentrantLock.CountdownLatch.CycliBarrier等并发工具的原理/基础,所以了解AQS的原理 ...
- make: 警告:检测到时钟错误。您的创建可能是不完整的。
我在make的时候也出现了同样的问题,不过不是什么大问题,这个不影响编译结果,但是强迫症还是希望能解决掉 分析原因可能是:服务器上的文件最后修改时间比当前时钟要晚 解决办法:用touch 命令把源程序 ...
- 微信小程序page的生命周期和音频播放及监听
一.界面的生命周期 /** * 监听页面加载, * 页面加载中 */ onLoad:function(){ var _this = this console.log('index---------on ...