【最小表示法】BZOJ2882-工艺
【题目大意】
求一个循环数列的最小表示法。
【思路】
最小表示法模板题。之前用SAM做的,MLE了hhhhh戳☆
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=+;
int s[MAXN*],n; void init()
{
scanf("%d",&n);
for (int i=;i<n;i++)
{
scanf("%d",&s[i]);
s[i+n]=s[i];
}
} void solve()
{
int i=,j=,k=;
while (k<n)
{
int t=s[(i+k)%(*n)]-s[(j+k)%(*n)];//不要忘记了这里要mod
if (t==) k++;
else
{
if (t>) i+=k+;
else j+=k+;
if (i==j) j++;
k=;
}
}
for (int r=,now=i;r<=k;r++,now=(now+)%(*n))
{
printf("%d",s[now]);
if (r!=k) printf(" ");
}
} int main()
{
init();
solve();
return ;
}
【最小表示法】BZOJ2882-工艺的更多相关文章
- bzoj2882工艺(最小表示法)
		O(nlogn)的做法十分显然,有三种可以做到O(nlogn)的:1.最容易的想法:把串扩展成两倍,然后跑一遍SA求后缀数组.2.求后缀同样也可以用SAM去求解,用map存一下.3.最暴力的方法:直接 ... 
- BZOJ2882 工艺【SAM】 最小循环串
		BZOJ2882 工艺 给出一个串,要求其循环同构串中字典序最小的那个 串翻倍建\(SAM\)然后从起点开始贪心的跑\(n\)次即可 当然也能用最小表示法来做 #include<bits/std ... 
- P1368 工艺 SA/最小表示法
		正解:SA/最小表示法 解题报告: 传送门! 听说正解是最小表示法,,,O(n)然后常数还挺小的,,, 但是我不会QAQ! 所以先写下SA的做法趴,,,等get了最小表示法再来写正解QAQ 就这种题算 ... 
- luoguP1368 工艺(最小表示法 后缀自动机)
		最小表示法就是直接扫过去 后缀自动机就是每次找最字典序最小儿子输出 最小表示法 /* 最小表示法裸题, 我好像学过来着?? 怎么忘得这么干净 */ #include<cstdio> #in ... 
- 2018.07.17 洛谷P1368 工艺(最小表示法)
		传送门 好的一道最小表示法的裸板,感觉跑起来贼快(写博客时评测速度洛谷第二),这里简单讲讲最小表示法的实现. 首先我们将数组复制一遍接到原数组队尾,然后维护左右指针分别表示两个即将进行比较的字符串的头 ... 
- 算法复习——最小表示法(bzoj2882)
		题目: Description 小敏和小燕是一对好朋友. 他们正在玩一种神奇的游戏,叫Minecraft. 他们现在要做一个由方块构成的长条工艺品.但是方块现在是乱的,而且由于机器的要求,他们只能做到 ... 
- BZOJ 2882 工艺 ——后缀自动机 最小表示法
		先说后缀自动机的做法. 直接把S串复制一遍成SS,然后建立后缀自动机,go边相当于在当前字符的后面插入,而son边可以看作在字符串前面加一个字符. 所以贪心的走字典序最小的边即可,而且根据后缀自动机的 ... 
- BZOJ 2882: 工艺 (SA/SAM/最小表示法)
		我写的O(nlogn)O(nlogn)O(nlogn)的SA 8000ms 被 O(n)O(n)O(n)的SAM 2800ms 和 O(n)O(n)O(n)的最小表示法 500ms 头都锤爆- COD ... 
- HDU 4162 Shape Number (最小表示法)
		题意:给你一串n个数,求出循环来看一阶差的最小字典序:数字串看成一个顺时针的环,从某一点开始顺时针循环整个环,保证字典序最小就是答案 例如给你 2 1 3 就会得到(1-2+8 注意题意负数需要加8) ... 
- POJ 1635 树的最小表示法/HASH
		题目链接:http://poj.org/problem?id=1635 题意:给定两个由01组成的串,0代表远离根,1代表接近根.相当于每个串对应一个有根的树.然后让你判断2个串构成的树是否是同构的. ... 
随机推荐
- 【leetcode 简单】第三十九题 Excel表列名称
			给定一个正整数,返回它在 Excel 表中相对应的列名称. 例如, 1 -> A 2 -> B 3 -> C ... 26 -> Z 27 -> AA 28 -> ... 
- bootstrap分页查询传递中文参数到后台(get方式提交)
			<!--分页 --> <div style="width: 380px; margin: 0 auto; margin-top: 50px;"> <u ... 
- Codeforces 870E Points, Lines and Ready-made Titles 计数
			题目链接 题意 给定二维坐标上的\(n\)个点,过每个点可以 画一条水平线 或 画一条竖直线 或 什么都不画,并且若干条重合的直线被看做同一条.问共可能得到多少幅不同的画面? 题解 官方题解 仆の瞎扯 ... 
- go语言基本介绍
			Golang发展历史 1. 诞生历史a. 诞生与2006年1月2号下午15点4分5秒b. 2009发布并正式开源c. 2012年第一个正式版本Go 1.0发布d. 截至到2017年8月24号Go 1. ... 
- linux 内核信号量
			Linux内核的信号量在概念和原理上和用户态的System V的IPC机制信号量是相同的,不过他绝不可能在内核之外使用,因此他和System V的IPC机制信号量毫不相干. 信号量在创建时需要设置一个 ... 
- 使用 Xtrabackup 在线对MySQL做主从复制【转】
			1. 说明 1.1 xtrabackup mysqldump对于导出10G以下的数据库或几个表,还是适用的,而且更快捷.一旦数据量达到100-500G,无论是对原库的压力还是导出的性能,mysqldu ... 
- ios 不支持iframe 解决方案
			在iframe外层在包一层,通过appendChild()把内容增加到容器中,完整代码如下: @section Css { <link href="@ViewHelper.Conten ... 
- Ubuntu每次开机后提示:检测到系统程序出现问题的解决方法
			首先,错误报告存放位置: cd /var/crash/ ls //可以查看错误报告 1 2 sudo rm /var/crash/* //删除该目录下的所有文件 1 但是,这只是删除掉的是错误报告,如 ... 
- 9.Python3标准库--数据压缩与归档
			''' 尽管现代计算机系统的存储能力日益增长,但生成数据的增长是永无休止的. 无损(lossless)压缩算法以压缩或解压缩数据花费的时间来换取存储数据所需要的空间,以弥补存储能力的不足. Pytho ... 
- linux的fwrite()使用方法,当前时间写入文本的程序
			fwrite函数 1.函数功能 用来读写一个数据块. 2.一般调用形式 fwrite(buffer,size,count,fp); 3.说明 (1)buffer:是一个指针,对fread来说,它是读入 ... 
