描述
输入两个字符串S和L,都只包含英文小写字母。$长度<=100,L长度<=500,000。
判定S是否是L的有效子串。
判定规则:
S中的每个字符在L中都能找到(可以不连续),且S在L中字符的前后顺序与S中顺序要保持一致。(例如,S=”aceQ"是L="abcde”的一个子序列且有效字符是a、c、e,而”aec"不是有效子序列,且有效字符只有a、e)。
输入描述:
输入两个字符串S和L,都只包含英文小写字母。S长度<=100,L长度<=500,000。
先输入S,再输入L,每个字符串占一行。
输出描述:
S串最后一个有效字符在L中的位置。(首位从0开始计算,无有效字符返回-1)。
用例:
输入:
ace
abcde
输出:
4
java代码实现
package com.des.data.test;
public class StringSequenceDetermination {
public static void main(String[] args) {
String S = "ace";
String L = "abcde";
System.out.println(solution(S,L));
}
public static int solution(String S, String L) {
int start = -1;
for (int i = 0; i < S.length(); i++) {
char ci = S.charAt(i);
for (int j = start+1; j < L.length(); j++) {
char cj = L.charAt(j);
if (ci == cj) {
start = j;
break;
}
}
}
return start;
}
}