워커 연습경기 17B 좋은 자리.DP
1396 단어 DP
|s|, |x|<=2e5는 s의 위치가 모두 좋은 위치인지 물어봅니다.
i가 좋은 위치인지 판단하면 접두사 i, 접두사 i+1으로 나눌 수 있다.
s의 접두사 i는 x가 일치하는 위치가 분명히 뒤일수록 좋다.
pre[i]를 접두사 i로 설정하면 최대 몇 개까지 일치할 수 있습니다.f[i]는 위치 i로 끝나는 하위 시퀀스와 최대 몇 개까지 일치합니다.
f[i]<=pre[i], f[i]=x[1:pre[i]]에서 마지막으로 s[i]가 나오는 위치.
그러면 s[i+1:n]에 x[f[i]+1:m]라는 하위 서열이 있습니까?
s,x를 뒤집어 위와 같이 처리하면 됩니다.
#include
using namespace std;
const int N=2e5+5;
char s[N],x[N];
int p[N],f[N],suf[N],h[N],n,m;
vector v[30];
int main()
{
scanf("%s%s",s+1,x+1);
n=strlen(s+1),m=strlen(x+1);
for(int i=1;x[i];i++)
v[x[i]-'a'].push_back(i);
for(int i=1;s[i];i++)
{
int id=s[i]-'a';
p[i]=p[i-1];
if(p[i]==m)
{
if(v[id].size())
f[i]=v[id][v[id].size()-1];
}
else
{
if(x[p[i-1]+1]==s[i])
p[i]=p[i-1]+1;
int pos=upper_bound(v[id].begin(),v[id].end(),p[i])-v[id].begin();
if(pos)
f[i]=v[id][pos-1];
}
}
reverse(s+1,s+1+n);
reverse(x+1,x+1+m);
for(int i=0;i<30;i++)
v[i].clear();
for(int i=1;x[i];i++)
v[x[i]-'a'].push_back(i);
for(int i=1;s[i];i++)
{
int id=s[i]-'a';
suf[i]=suf[i-1];
if(s[i]==x[suf[i-1]+1])
suf[i]++;
}
bool flag=true;
for(int i=1;i<=n;i++)
{
int ned=m-f[i];
if(suf[n-i]
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[BOJ]11048(python)python 풀이 DP를 이용해 풀이 보통 이런 문제는 dfs나 bfs로 풀이하는 것이여서 고민을 했는데 이 문구 덕분에 DP 를 이용해 풀이할 수 있었다 뒤로 돌아가는 등의 경우를 고려하지 않아도 되기 때문이다 코...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.