-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path392.is-subsequence.cpp
More file actions
67 lines (66 loc) · 1.52 KB
/
392.is-subsequence.cpp
File metadata and controls
67 lines (66 loc) · 1.52 KB
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
65
66
67
/*
* @lc app=leetcode id=392 lang=cpp
*
* [392] Is Subsequence
*
* https://leetcode.com/problems/is-subsequence/description/
*
* algorithms
* Easy (50.48%)
* Likes: 5275
* Dislikes: 309
* Total Accepted: 529.3K
* Total Submissions: 1M
* 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
{
public:
bool isSubsequence(string s, string t)
{
unsigned short short int i = 0, j = 0;
while (i < s.size() && j < t.size())
{
if (s[i] == t[j])
{
i++;
j++;
}
else
j++;
}
return i == s.size();
}
};
// @lc code=end