Two Pointers
就像在閱讀時用手指頭一樣,在數組中也使用兩個”指針”。這兩個指針會在數組中移動來找到我們需要的答案。有時,這兩個指針會一起移動;有時,一個會比另一個移動得快;有時,它們甚至會從數組的兩個方向向中間移動。通常用它來處理找range的sum。
Sliding Window
Sliding Window是Two Pointer的一種,通常用它來處理連續數字的問題。可以想象在數組上設置了一個”窗口”,這個窗口可以變大也可以變小,就像房間裡的窗戶一樣。這個窗口會在數組中滑動,並且通常會對這個窗口內的數字進行某種計算(比如求和或者找最大值等)。
3. Longest Substring Without Repeating Characters
data:image/s3,"s3://crabby-images/427df/427dfec60755b6815f2f432ea4a0dc433e154c08" alt=""
1151. Minimum Swaps to Group All 1’s Together
data:image/s3,"s3://crabby-images/23df6/23df6953ec45d9f02c9a224b6a0c2a9155bad9d4" alt=""
219. Contains Duplicate II
data:image/s3,"s3://crabby-images/077e8/077e87618279bb7fb87708b0d812ef2e80f88986" alt=""
1876. Substrings of Size Three with Distinct Characters
data:image/s3,"s3://crabby-images/01d61/01d61f1a52bc723791dd5d247126f7f3cc8c8bd9" alt=""
1176. Diet Plan Performance
data:image/s3,"s3://crabby-images/b8b52/b8b52c5e49f1c9b7817032f5b9449d5a8905e29d" alt=""
340. Longest Substring with At Most K Distinct Characters
data:image/s3,"s3://crabby-images/975cb/975cb7973a2ab1dbdd94d00882e5a369c51fb9c4" alt=""