상세 컨텐츠

본문 제목

16229번: 반복 패턴 - Z

알고리즘/baekjoon

by oVeron 2024. 7. 21. 08:46

본문

728x90
반응형

Z 응용 문제.

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
typedef tuple<ll, ll, ll> tll;

const int MAXN = 100001;
int N, K;
string S;
int Z[MAXN];

bool solve(int idx, int len)
{
    if(Z[idx] <= len && idx+Z[idx] == N)
    {
        if(len-Z[idx] <= K) return true; //K개의 글자로 패턴의 길이를 만들 수 있으면 true return
        else return false;
    }
    if(Z[idx] >= len) return solve(idx+len, len); //Z 배열이 등차수열을 이뤄야 한다.
    return false;
}

int main()
{
    ios::sync_with_stdio(0);
	cin.tie(0), cout.tie(0);
	
	cin >> N >> K;
	cin >> S;
	
	int l = 0, r = 0;
	for(int i=1; i<N; i++)
	{
	    Z[i] = (i > r) ? 0 : min(r-i+1, Z[i-l]);
	    while(i+Z[i] < N && S[Z[i]] == S[i+Z[i]]) Z[i]++;
	    if(i+Z[i]-1 > r) l = i, r = i+Z[i]-1;
	}
	
	int ans = 0;
	if(N <= K) ans = N;
	else
	{
	    for(int i=1; i<N; i++) 
	        if(solve(i, i)) ans = i;
	}
	cout << ans;
}
728x90
반응형

관련글 더보기

댓글 영역