-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path392.is-subsequence.py
64 lines (62 loc) · 1.57 KB
/
392.is-subsequence.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#
# @lc app=leetcode id=392 lang=python3
#
# [392] Is Subsequence
#
# https://leetcode.com/problems/is-subsequence/description/
#
# algorithms
# Easy (48.18%)
# Likes: 10053
# Dislikes: 570
# Total Accepted: 1.9M
# Total Submissions: 3.9M
# Testcase Example: '"abc"\n"ahbgdc"'
#
# Given two strings s and t, return true if s is a subsequence of t, or false
# otherwise.
#
# A subsequence of a string is a new string that is formed from the original
# string by deleting some (can be none) of the characters without disturbing
# the relative positions of the remaining characters. (i.e., "ace" is a
# subsequence of "abcde" while "aec" is not).
#
#
# Example 1:
# Input: s = "abc", t = "ahbgdc"
# Output: true
# Example 2:
# Input: s = "axc", t = "ahbgdc"
# Output: false
#
#
# Constraints:
#
#
# 0 <= s.length <= 100
# 0 <= t.length <= 10^4
# s and t consist only of lowercase English letters.
#
#
#
# Follow up: Suppose there are lots of incoming s, say s1, s2, ..., sk where k
# >= 10^9, and you want to check one by one to see if t has its subsequence. In
# this scenario, how would you change your code?
#
# @lc code=start
class Solution:
def isSubsequence(self, s: str, t: str) -> bool:
start_index = 0
finish_index = len(s)
for i, char in enumerate(t):
if finish_index == 0:
return True
if char == s[start_index]:
start_index += 1
finish_index -= 1
# print(start_index)
if start_index == len(s):
return True
else:
return False
# @lc code=end