LeetCode 392. 判斷子序列

題目鏈接 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去解決吧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章