C. Two strings
time limit per test:2 seconds
memory limit per test:256 megabytes
input:standard input
output:standard output
You are given two strings a and b. You have to remove the minimum possible number of consecutive (standing one after another) characters from string b in such a way that it becomes a subsequence of string a. It can happen that you will not need to remove any characters at all, or maybe you will have to remove all of the characters from b and make it empty.
Subsequence of string s is any such string that can be obtained by erasing zero or more characters (not necessarily consecutive) from string s.
Input
The first line contains string a, and the second line — string b. Both of these strings are nonempty and consist of lowercase letters of English alphabet. The length of each string is no bigger than 105 characters.
Output
On the first line output a subsequence of string a, obtained from b by erasing the minimum number of consecutive characters.
If the answer consists of zero characters, output ?-? (a minus sign).
Examples
Input hi bob
Input abca accepted
Output ac
Input abacaba abcdcba
Output abcba
Note
In the first example strings a and b don’t share any symbols, so the longest string that you can get is empty.
In the second example ac is a subsequence of a, and at the same time you can obtain it by erasing consecutive symbols cepted from string b. 題意:給兩個字符串a.b,將b刪除連續的一部分后,成為a的子串,問這個最大子串,沒有輸出”-“. 題解:大神詳解 代碼:
#include <bits/stdc++.h>using namespace std;const int N=100005;char a[N],b[N];int lena,lenb,L,R;int needh[N],needl[N];int main(){ scanf("%s",a+1); scanf("%s",b+1); lena=strlen(a+1); lenb=strlen(b+1); for(int i=1;i<=lenb;i++) needh[i]=needl[i]=lena+1; int pos=1; L=lenb; R=1; for(int i=1;i<=lenb;i++) { while(pos<=lena&&a[pos]!=b[i])++pos; if(pos<=lena) needh[i]=pos; else { L=i-1; break; } ++pos; } pos=lena; for(int i=lenb;i>=1;i--) { while(pos>=1&&a[pos]!=b[i]) --pos; if(pos>=1) needl[i]=lena-pos+1; else { R=i+1; break; } --pos; } if(L<1&&R>lenb)新聞熱點
疑難解答