-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path001.py
54 lines (47 loc) · 1.7 KB
/
001.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
class Solution:
"""
@param source:
@param target:
@return: return the index
"""
def str_str1(self, source: str, target: str) -> int:
# Write your code here
#print('source:',source)
#print('target:',target)
sourceLen=len(source)
targetLen=len(target)
if targetLen==0:return 0
if targetLen>sourceLen:return -1
return source.index(target)
def str_str2(self, source, target):
sourceLen=len(source)
targetLen=len(target)
#print(sourceLen,targetLen)
if targetLen==0:return 0
if targetLen>sourceLen:return -1
for i in range(sourceLen - targetLen +1):
for j in range(targetLen):
if source[j+i]==target[j]:
if j==targetLen-1: return i
else: break
return -1
def main():
S=Solution()
source = "abcdabcdefg"; target = "bcd"
print('------source=%s,target=%s'.format(source,target))
print('str1:',S.str_str1(source,target))
print('str2:',S.str_str2(source,target))
source = "a"; target = "bcd"
print('------source=%s,target=%s'.format(source,target))
print('str1:',S.str_str1(source,target))
print('str2:',S.str_str2(source,target))
source = "abc"; target = ""
print('------source=%s,target=%s'.format(source,target))
print('str1:',S.str_str1(source,target))
print('str2:',S.str_str2(source,target))
source = "abc"; target = "edgef"
print('------source=%s,target=%s'.format(source,target))
print('str1:',S.str_str1(source,target))
print('str2:',S.str_str2(source,target))
if __name__ == "__main__":
main()