国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Educational Codeforces Round 17 C. Two strings(二分)

2019-11-11 04:55:37
字體:
來源:轉載
供稿:網友

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

Output

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)
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鸡泽县| 攀枝花市| 玉门市| 桃源县| 沽源县| 芜湖县| 册亨县| 图木舒克市| 县级市| 图木舒克市| 鄯善县| 鸡西市| 马尔康县| 西充县| 大安市| 巴彦淖尔市| 宁都县| 搜索| 安塞县| 名山县| 古田县| 玉龙| 宝鸡市| 化德县| 长顺县| 阿坝| 紫云| 临澧县| 郓城县| 英德市| 城步| 宁都县| 荥阳市| 罗定市| 恭城| 新营市| 博兴县| 曲阳县| 长垣县| 桐乡市| 蒲城县|