題目鏈接 LeetCode 392. 判斷子序列
題目描述
給定字符串 s 和 t ,判斷 s 是否爲 t 的子序列。
你可以認爲 s 和 t 中僅包含英文小寫字母。字符串 t 可能會很長(長度 ~= 500,000),而 s 是個短字符串(長度 <=100)。
字符串的一個子序列是原始字符串刪除一些(也可以不刪除)字符而不改變剩餘字符相對位置形成的新字符串。(例如,"ace"是"abcde"的一個子序列,而"aec"不是)。
示例 1:
s = “abc”, t = “ahbgdc”
返回 true.
示例 2:
s = “axc”, t = “ahbgdc”
返回 false.
解題思路
用兩個指針,一個指針i用來控制子序列,一個指針j用來控制母序列,如果相等就i++ j++,如果不等就只移動j指針,j++。
程序代碼
c++
class Solution {
public:
bool isSubsequence(string s, string t) {
int ls=s.size()-1,ts=t.size()-1;
int i=0,j=0;
while(i<=ls&&j<=ts) {
if(s[i]==t[j]) {i++;j++;}
else j++;
}
if(i==ls+1) return true;
else return false;
}
};
思考
後續挑戰 :
如果有大量輸入的 S,稱作S1, S2, … , Sk 其中 k >= 10億,你需要依次檢查它們是否爲 T 的子序列。在這種情況下,你會怎樣改變代碼?
題目給出了一個思考,好像這個可以用kmp去解決吧。