diff options
author | chriseth <chris@ethereum.org> | 2018-02-10 00:53:30 +0800 |
---|---|---|
committer | Alex Beregszaszi <alex@rtfs.hu> | 2018-02-13 23:04:10 +0800 |
commit | 5747985e6a272edd512d53b2da438577fe461bb6 (patch) | |
tree | bf12653b1e6b51be863b120429ff3a2508e8b28d | |
parent | 12c3eb8880bd6c50b5fd0aad76626fcce4f663b5 (diff) | |
download | dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar.gz dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar.bz2 dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar.lz dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar.xz dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.tar.zst dexon-solidity-5747985e6a272edd512d53b2da438577fe461bb6.zip |
Use one-dimensional vector.
-rw-r--r-- | libdevcore/StringUtils.cpp | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/libdevcore/StringUtils.cpp b/libdevcore/StringUtils.cpp index c4b1d5a9..2ff86bd5 100644 --- a/libdevcore/StringUtils.cpp +++ b/libdevcore/StringUtils.cpp @@ -48,7 +48,8 @@ size_t dev::stringDistance(string const& _str1, string const& _str2) size_t n1 = _str1.size(); size_t n2 = _str2.size(); // Optimize by storing only last 2 rows and current row. So first index is considered modulo 3 - vector<vector<size_t>> dp(3, vector<size_t>(n2 + 1)); + // This is a two-dimensional array of size 3 x (n2 + 1). + vector<size_t> dp(3 * (n2 + 1)); // In this dp formulation of Damerau–Levenshtein distance we are assuming that the strings are 1-based to make base case storage easier. // So index accesser to _name1 and _name2 have to be adjusted accordingly @@ -60,9 +61,9 @@ size_t dev::stringDistance(string const& _str1, string const& _str2) x = max(i1, i2); else { - size_t left = dp[(i1-1) % 3][i2]; - size_t up = dp[i1 % 3][i2-1]; - size_t upleft = dp[(i1 - 1) % 3][i2-1]; + size_t left = dp[(i1 - 1) % 3 + i2 * 3]; + size_t up = dp[(i1 % 3) + (i2 - 1) * 3]; + size_t upleft = dp[((i1 - 1) % 3) + (i2 - 1) * 3]; // deletion and insertion x = min(left + 1, up + 1); if (_str1[i1-1] == _str2[i2-1]) @@ -74,12 +75,12 @@ size_t dev::stringDistance(string const& _str1, string const& _str2) // transposing if (i1 > 1 && i2 > 1 && _str1[i1 - 1] == _str2[i2 - 2] && _str1[i1 - 2] == _str2[i2 - 1]) - x = min(x, dp[(i1 - 2) % 3][i2 - 2] + 1); + x = min(x, dp[((i1 - 2) % 3) + (i2 - 2) * 3] + 1); } - dp[i1 % 3][i2] = x; + dp[(i1 % 3) + i2 * 3] = x; } - return dp[n1 % 3][n2]; + return dp[(n1 % 3) + n2 * 3]; } string dev::quotedAlternativesList(vector<string> const& suggestions) |