hdu3746 KMP的next数组应用,求项链首尾项链循环
来源:互联网 发布:sql分组累计求和 编辑:程序博客网 时间:2024/05/29 15:44
题意:
给你一个项链,问你最少加多少个珠子能满足整个项链是一个循环的项链(首尾相连)
思路:
KMP的简单应用只要了解next数组的意义就好说了,下面总结下
next在循环方面的常用应用
(1)i - next[i] 最小循环节(第一个字母开始)
(2)next[i] 最大循环节中的第几位数(此时循环节可交叉)
(3)next[i] != 0 && i % (i - next[i]) == 0,当前是循环节中的最 后一位.
(4)在(3)的前提下 i / (i - next[i]) 表示的最大周期个数,也就是在最小循环节的前提下的最大周期个数。那么这个题目就好办了,先求出,如果next[n] && n % (n - next[n])
给你一个项链,问你最少加多少个珠子能满足整个项链是一个循环的项链(首尾相连)
思路:
KMP的简单应用只要了解next数组的意义就好说了,下面总结下
next在循环方面的常用应用
(1)i - next[i] 最小循环节(第一个字母开始)
(2)next[i] 最大循环节中的第几位数(此时循环节可交叉)
(3)next[i] != 0 && i % (i - next[i]) == 0,当前是循环节中的最 后一位.
(4)在(3)的前提下 i / (i - next[i]) 表示的最大周期个数,也就是在最小循环节的前提下的最大周期个数。那么这个题目就好办了,先求出,如果next[n] && n % (n - next[n])
直接输出0,因为此时最后一个是循环节上的数字,并且是最后一个。否则就输出(n - next[n]) - n % (n - next[n])
#include<stdio.h>#include<string.h>#define N 100000 + 100int next[N];char str[N];void get_next(int m){ int j ,k; j = 0 ,k = -1; next[0] = -1; while(j < m) { if(k == -1 || str[j] == str[k]) next[++j] = ++k; else k = next[k]; } return ;}int main (){ int t ,i ,m; scanf("%d" ,&t); while(t--) { scanf("%s" ,str); m = strlen(str); get_next(m); if(next[m] && m % (m - next[m]) == 0) puts("0"); else printf("%d\n" ,(m - next[m]) - m % (m - next[m])); } return 0;}
0 0
- hdu3746 KMP的next数组应用,求项链首尾项链循环
- hdu3746(KMP:next数组应用)
- HDU3746——Simpsons’ Hidden Talents(KMP中next数组的应用)
- 【KMP】 hdu3746 kmp求循环节长度
- HDU3746 kmp算法以及next数组
- hdu3746(KMP next数组使用)
- hdu1358 kmp的next数组求循环节
- KMP next数组求最小循环节
- HDU3746(KMP求循环节)
- KMP算法-next数组的应用-循环节问题
- ZJUT1315 同种项链 KMP
- kmp求next数组值的方法
- KMP算法 求next数组的原理
- KMP算法求next数组的方法
- 带表头的循环单项链表
- HDU3746-KMP循环节
- kmp的next数组的运用(求字符串的最小循环节)
- HDU 3746 Cyclic Nacklace 利用 KMP的next数组求循环节
- 21、下载整个网站。
- 模式匹配KMP POJ 3461
- OCP-1Z0-051 第148题 子查询和ANY,ALL的使用
- c++中 类的相关事项(1)
- 【不明觉厉,厚积薄发】ARM_linux(四)
- hdu3746 KMP的next数组应用,求项链首尾项链循环
- android listview 不显示选中效果分析
- 动态库转静态库不爽记
- 第十二周上机实践项目——摩托车继承自行车和机动车
- linux顶层Makefile(不错)
- 大学生活的点滴感悟
- 分数类中的运算符重载
- 香港特区政府接获8宗港人在越南
- 背包问题