給定字符串 s 和 t ,判斷 s 是否爲 t 的子序列。 ide
你能夠認爲 s 和 t 中僅包含英文小寫字母。字符串 t 可能會很長(長度 ~= 500,000),而 s 是個短字符串(長度 <=100)。 spa
字符串的一個子序列是原始字符串刪除一些(也能夠不刪除)字符而不改變剩餘字符相對位置造成的新字符串。(例如,"ace"是"abcde"的一個子序列,而"aec"不是)。 字符串
示例 1:
s = "abc", t = "ahbgdc" it
返回 true. io
示例 2:
s = "axc", t = "ahbgdc" class
返回 false. 英文
後續挑戰 : di
若是有大量輸入的 S,稱做S1, S2, ... , Sk 其中 k >= 10億,你須要依次檢查它們是否爲 T 的子序列。在這種狀況下,你會怎樣改變代碼? view
1 class Solution { 2 public boolean isSubsequence(String s, String t) { 3 int sindex = 0, tindex = 0; 4 while(sindex < s.length() && tindex < t.length()) { 5 if(s.charAt(sindex) == t.charAt(tindex)) { 6 sindex++; 7 } 8 tindex++; 9 } 10 if(sindex == s.length()) return true; 11 return false; 12 } 13 }