From e7d22b488362e0425b52f92d52c25ae89fe95974 Mon Sep 17 00:00:00 2001 From: Oleksii Trekhleb Date: Thu, 9 Aug 2018 06:05:09 +0300 Subject: [PATCH] Use '===' for double check string comparision in RabinKarp. --- src/algorithms/string/rabin-karp/rabinKarp.js | 29 ++----------------- 1 file changed, 3 insertions(+), 26 deletions(-) diff --git a/src/algorithms/string/rabin-karp/rabinKarp.js b/src/algorithms/string/rabin-karp/rabinKarp.js index be61bf2442..9084eb4084 100644 --- a/src/algorithms/string/rabin-karp/rabinKarp.js +++ b/src/algorithms/string/rabin-karp/rabinKarp.js @@ -1,29 +1,5 @@ import PolynomialHash from '../../cryptography/polynomial-hash/PolynomialHash'; -/** - * Checks if two strings are equal. - * - * We may simply compare (string1 === string2) but for the - * purpose of analyzing algorithm time complexity let's do - * it character by character. - * - * @param {string} string1 - * @param {string} string2 - */ -function stringsAreEqual(string1, string2) { - if (string1.length !== string2.length) { - return false; - } - - for (let charIndex = 0; charIndex < string1.length; charIndex += 1) { - if (string1[charIndex] !== string2[charIndex]) { - return false; - } - } - - return true; -} - /** * @param {string} text - Text that may contain the searchable word. * @param {string} word - Word that is being searched in text. @@ -52,10 +28,11 @@ export default function rabinKarp(text, word) { prevFrame = currentFrame; // Compare the hash of current substring and seeking string. - // In case if hashes match let's check substring char by char. + // In case if hashes match let's make sure that substrings are equal. + // In case of hash collision the strings may not be equal. if ( wordHash === currentFrameHash - && stringsAreEqual(text.substr(charIndex, word.length), word) + && text.substr(charIndex, word.length) === word ) { return charIndex; }