hdu3746 KMP的next数组应用,求项链首尾项链循环
生活随笔
收集整理的這篇文章主要介紹了
hdu3746 KMP的next数组应用,求项链首尾项链循环
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題意:
? ? ? 給你一個(gè)項(xiàng)鏈,問你最少加多少個(gè)珠子能滿足整個(gè)項(xiàng)鏈?zhǔn)且粋€(gè)循環(huán)的項(xiàng)鏈(首尾相連)
思路:
? ? ?KMP的簡單應(yīng)用只要了解next數(shù)組的意義就好說了,下面總結(jié)下
?next在循環(huán)方面的常用應(yīng)用
(1)i - next[i] 最小循環(huán)節(jié)(第一個(gè)字母開始)
(2)next[i] 最大循環(huán)節(jié)中的第幾位數(shù)(此時(shí)循環(huán)節(jié)可交叉)
(3)next[i] != 0 && i % (i - next[i]) == 0,當(dāng)前是循環(huán)節(jié)中的最 ??后一位.
(4)在(3)的前提下 i / (i - next[i]) 表示的最大周期個(gè)數(shù),也就是在最小循環(huán)節(jié)的前提下的最大周期個(gè)數(shù)。那么這個(gè)題目就好辦了,先求出,如果next[n] && n % (n - next[n])
? ? ? 給你一個(gè)項(xiàng)鏈,問你最少加多少個(gè)珠子能滿足整個(gè)項(xiàng)鏈?zhǔn)且粋€(gè)循環(huán)的項(xiàng)鏈(首尾相連)
思路:
? ? ?KMP的簡單應(yīng)用只要了解next數(shù)組的意義就好說了,下面總結(jié)下
?next在循環(huán)方面的常用應(yīng)用
(1)i - next[i] 最小循環(huán)節(jié)(第一個(gè)字母開始)
(2)next[i] 最大循環(huán)節(jié)中的第幾位數(shù)(此時(shí)循環(huán)節(jié)可交叉)
(3)next[i] != 0 && i % (i - next[i]) == 0,當(dāng)前是循環(huán)節(jié)中的最 ??后一位.
(4)在(3)的前提下 i / (i - next[i]) 表示的最大周期個(gè)數(shù),也就是在最小循環(huán)節(jié)的前提下的最大周期個(gè)數(shù)。那么這個(gè)題目就好辦了,先求出,如果next[n] && n % (n - next[n])
直接輸出0,因?yàn)榇藭r(shí)最后一個(gè)是循環(huán)節(jié)上的數(shù)字,并且是最后一個(gè)。否則就輸出(n - next[n]) - n % (n - next[n])
#include<stdio.h> #include<string.h>#define N 100000 + 100 int 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;elsek = 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");elseprintf("%d\n" ,(m - next[m]) - m % (m - next[m]));}return 0; }
總結(jié)
以上是生活随笔為你收集整理的hdu3746 KMP的next数组应用,求项链首尾项链循环的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hdu4067 费用流(混合欧拉的宽展和
- 下一篇: hdu1358 最小循环节,最大循环次数