博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 4162 Shape Number
阅读量:4329 次
发布时间:2019-06-06

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

题目链接:

题意:

求给定字符的一阶差分链的最小表示。

题解:

先求一阶差分链,再求一阶差分链的最小表示法。

代码:

跑了670MS

#include
#include
#include
using namespace std;const int maxn = 3e5 + 10;char s1[maxn],s2[maxn];int solve(char *s) { int i = 0, j = 1, k = 0,len=strlen(s); while (i < len&&j < len&&k
0) i = i + k + 1; else j = j + k + 1; if (i == j) j++; k = 0; } } return i < j ? i : j;}int main() { while (scanf("%s", s1) == 1) { int len = strlen(s1); for (int i = 0; i < len; i++) { s2[i] = (s1[(i + 1) % len] - s1[i] + 8) % 8 + '0'; } s2[len] = '\0'; //cout << s2 << endl; int pos = solve(s2); for (int i = 0; i < len; i++) { printf("%c", s2[(pos + i) % len]); } printf("\n"); } return 0;}

 

贴个后缀数组的解法:

跑了2527MS

#include#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define X first#define Y second#define mkp make_pair#define lson (o<<1)#define rson ((o<<1)|1)#define mid (l+(r-l)/2)#define sz() size()#define pb(v) push_back(v)#define all(o) (o).begin(),(o).end()#define clr(a,v) memset(a,v,sizeof(a))#define bug(a) cout<<#a<<" = "<
<
VI;typedef pair
PII;typedef vector
> VPII;const int INF=0x3f3f3f3f;const LL INFL=0x3f3f3f3f3f3f3f3fLL;const double eps=1e-8;const int maxn = 3e5 + 10;char s1[maxn],s2[maxn];struct SuffixArray{ char s[maxn]; int sa[maxn],t[maxn],t2[maxn],c[maxn]; int n,m; void init(int n,int m){ this->n=n; this->m=m; } void build_sa(){ int i,*x=t,*y=t2; for(i=0;i
=0;i--) sa[--c[x[i]]]=i; for(int k=1;k<=n;k<<=1){ int p=0;// for(i=n-k;i
=k) y[p++]=sa[i]-k; for(i=0;i
=0;i--) sa[--c[x[y[i]]]]=y[i]; swap(x,y); p=1; x[sa[0]]=0; for(i=1;i
=n) break; m=p; } }}mysa;int main() { while (scanf("%s", s1) == 1) { int len = strlen(s1); mysa.init(len,256); for (int i = 0; i < len; i++) { s2[i] = (s1[(i + 1) % len] - s1[i] + 8) % 8 + '0'; } s2[len] = '\0'; strcpy(mysa.s,s2); mysa.build_sa(); for(int p=mysa.sa[0];p

 

转载于:https://www.cnblogs.com/fenice/p/5557650.html

你可能感兴趣的文章
RocketMQ配置
查看>>
vs code调试console程序报错--preLaunchTask“build”
查看>>
蚂蚁金服井贤栋:用技术联手金融机构,形成服务小微的生态合力
查看>>
端口号大全
查看>>
机器学习基石笔记2——在何时可以使用机器学习(2)
查看>>
POJ 3740 Easy Finding (DLX模板)
查看>>
MySQL 处理重复数据
查看>>
关于typedef的用法总结(转)
查看>>
【strtok()】——分割字符串
查看>>
Linux下安装rabbitmq
查看>>
曹德旺
查看>>
【转】判断点在多边形内(matlab)
查看>>
java基础之集合:List Set Map的概述以及使用场景
查看>>
Python 线程 进程 协程
查看>>
iOS语言中的KVO机制
查看>>
excel第一次打开报错 向程序发送命令时出错 多种解决办法含终极解决方法
查看>>
响应式web设计之CSS3 Media Queries
查看>>
实验三
查看>>
机器码和字节码
查看>>
环形菜单的实现
查看>>