1. 程式人生 > 實用技巧 >392.判斷子序列

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.

思路:

  • 從 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 ; } }