392.判斷子序列
阿新 • • 發佈:2020-11-04
給定字串 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.
思路:
• 從 0 開始遍歷字串 t 與 s ,當相等時,s 的下標右移;
• 不管是否相等,t 都右移。
class Solution { public boolean isSubsequence(String s, String t) { int n = s.length(), m = t.length(); int i = 0, j = 0; //i -> s , j -> t while(i < n && j < m){ if(s.charAt(i) == t.charAt(j)) i++; // 相等時,i++ j++; // 不管是否相等,j++ }return i == n ; } }