-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCheckIf2StringsAreEquivalent.py
61 lines (44 loc) · 1.45 KB
/
CheckIf2StringsAreEquivalent.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
'''
Given two string arrays word1 and word2, return true if the two arrays represent the same string, and false otherwise.
A string is represented by an array if the array elements concatenated in order forms the string.
Example 1:
Input: word1 = ["ab", "c"], word2 = ["a", "bc"]
Output: true
Explanation:
word1 represents string "ab" + "c" -> "abc"
word2 represents string "a" + "bc" -> "abc"
The strings are the same, so return true.
Example 2:
Input: word1 = ["a", "cb"], word2 = ["ab", "c"]
Output: false
Example 3:
Input: word1 = ["abc", "d", "defg"], word2 = ["abcddefg"]
Output: true
Constraints:
1 <= word1.length, word2.length <= 103
1 <= word1[i].length, word2[i].length <= 103
1 <= sum(word1[i].length), sum(word2[i].length) <= 103
word1[i] and word2[i] consist of lowercase letters.
'''
class Solution:
def arrayStringsAreEqual(self, word1: List[str], word2: List[str]) -> bool:
w1 = w2 = 0 #index of word
i = j = 0 # index of char in word
while w1 < len(word1) and w2 < len(word2):
if word1[w1][i] != word2[w2][j]:
return False
i, j = i+1, j+1
if i == len(word1[w1]):
w1 += 1
i = 0
if j == len(word2[w2]):
w2 += 1
j = 0
if w1 != len(word1) or w2!= len(word2):
return False
else:
return True
'''
Runtime 37 ms Beats 77.73%
Memory 16.5 MB Beats 13.49%
'''