-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanagramSubStringSearch.php
67 lines (41 loc) · 1.14 KB
/
anagramSubStringSearch.php
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
<?
//anangramsubstring search
function findAnagramSubstringSearch($string,$substring) {
if(!(is_string($string) && is_string($substring))) {
throw new Exception("Invalid string");
}
$countSubString = strlen($substring);
$countString = strlen($string);
if(($countSubString > $countString) && ($countSubString && $countString)) {
throw new Exception("Invalid string");
}
$mapSubString = array();
for($i=0;$i<$countSubString;$i++) {
$mapSubString[$substring[$i]]++;
}
$tempMap = $mapSubString;
$tempCount = $countSubString;
for($i = 0; $i < $countString; $i++) {
if(isset($tempMap[$string[$i]]) && $tempMap[$string[$i]]) {
$tempMap[$string[$i]]--;
$tempCount--;
if($tempCount) {
continue;
}
} elseif($tempCount == $countSubString) {
continue;
}
if(!$tempCount) {
$result[] = $i+1-$countSubString;
$tempMap[$string[$i+1-$countSubString]]++;
$tempCount = 1;
} else {
$tempMap = $mapSubString;
$tempCount = $countSubString;
}
}
return $result;
}
$string = "BACDGABCDA"; $substring = "ABCD";
$result = findAnagramSubstringSearch($string,$substring);
print_r($result);