Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Latest commit

 

History

History
History
33 lines (29 loc) · 1.17 KB

File metadata and controls

33 lines (29 loc) · 1.17 KB
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
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
/*
Pattern matching is case insensitive as
the inputs are converted to lower case before the
algorithm is run.
The algorithm will run through the entire text and
return the starting index if the given pattern is
available in the text
*/
const checkIfPatternExists = (text, pattern) => {
if (typeof text !== 'string' || typeof pattern !== 'string') {
throw new TypeError('Given input is not a string')
}
const textLength = text.length // Store the length of the text in a variable
const patternLength = pattern.length // Store the length of the pattern in a variable
// Iterate through the text until the textlength - patternlength index
for (let i = 0; i <= textLength - patternLength; i++) {
// For each character in the text check if the subsequent character
// are matching the given pattern; if not break from the condition
for (let j = 0; j < textLength; j++) {
if (text[i + j] !== pattern[j]) break
// For each iteration of j check if the value of
// j + 1 is equal to the length of the pattern
if (j + 1 === patternLength) {
return `Given pattern is found at index ${i}`
}
}
}
}
export { checkIfPatternExists }
Morty Proxy This is a proxified and sanitized view of the page, visit original site.