子串是一个字符串中连续的一部分,而子列是字符串中保持字符顺序的一个子集,可以连续也可以不连续。例如给定字符串 atpaaabpabtt
,pabt
是一个子串,而 pat
就是一个子列。
现给定一个字符串 S 和一个子列 P,本题就请你找到 S 中包含 P 的最短子串。若解不唯一,则输出起点最靠左边的解。
输入格式:
输入在第一行中给出字符串 S,第二行给出 P。S 非空,由不超过 104 个小写英文字母组成;P 保证是 S 的一个非空子列。
输出格式:
在一行中输出 S 中包含 P 的最短子串。若解不唯一,则输出起点最靠左边的解。
输入样例:
atpaaabpabttpcat
pat
输出样例:
pabt
解题思路:
遍历输出即可
#include <bits/stdc++.h>
using namespace std;
int main()
{
string n,m;
cin >> n >> m;
int point,left = 0,min = 10005;
for(int i = 0;i <= n.size() - m.size();++i)
{
if(n[i] == m[0])
{
point = 1;
for(int j = i+1;j < n.size();++j)
{
if(j-i == min) break;
if(m[point] == n[j]) ++point;
if(point == m.size() && j-i < min)
{
left = i;
min = j-i;
break;
}
}
}
}
cout << n.substr(left,min+1);
}