From 3280d46eb3ea1532b84fec260a6c150b2811781a Mon Sep 17 00:00:00 2001 From: "piotr.idzik" Date: Fri, 12 May 2023 22:56:37 +0200 Subject: [PATCH] fix: cleanup longest_common_string.cpp --- dynamic_programming/longest_common_string.cpp | 147 ++++++++++++------ 1 file changed, 102 insertions(+), 45 deletions(-) diff --git a/dynamic_programming/longest_common_string.cpp b/dynamic_programming/longest_common_string.cpp index 81fa8a002..bf8d4fef4 100644 --- a/dynamic_programming/longest_common_string.cpp +++ b/dynamic_programming/longest_common_string.cpp @@ -1,53 +1,110 @@ -#include -using namespace std; +/** + * @file + * @brief contains the definition of the function longest_common_string_length + * @details + * the function longest_common_string_length computes the length + * of the longest common string which can be created of two input strings + * by removing characters from them + */ -int max(int a, int b) { return (a > b) ? a : b; } +#include /// for assert +#include /// for std::string +#include /// for std::vector -int main() { - char str1[] = "DEFBCD"; - char str2[] = "ABDEFJ"; - int i, j, k; - int n = strlen(str1) + 1; - int m = strlen(str2) + 1; - // cout<> sub_sols( + size_a + 1, std::vector(size_b + 1, 0)); - for (i = 0; i < m; i++) { - for (j = 0; j < n; j++) { - if (i == 0 || j == 0) - a[i][j] = 0; - - else if (str1[i - 1] == str2[j - 1]) - a[i][j] = a[i - 1][j - 1] + 1; - - else - a[i][j] = 0; - } - } - - /*for(i=0;i ma) { - ma = a[i][j]; - indi = i; - indj = j; + const auto limit = static_cast(-1); + for (std::size_t pos_a = size_a - 1; pos_a != limit; --pos_a) { + for (std::size_t pos_b = size_b - 1; pos_b != limit; --pos_b) { + if (str_a[pos_a] == str_b[pos_b]) { + sub_sols[pos_a][pos_b] = 1 + sub_sols[pos_a + 1][pos_b + 1]; + } else { + sub_sols[pos_a][pos_b] = std::max(sub_sols[pos_a + 1][pos_b], + sub_sols[pos_a][pos_b + 1]); } } } - cout << str1 << "\n"; - cout << str2 << "\n"; - - cout << "longest string size = " << ma /*<<" "< get_test_cases() { + return {TestCase("", "", 0), + TestCase("ab", "ab", 2), + TestCase("ab", "ba", 1), + TestCase("", "xyz", 0), + TestCase("abcde", "ace", 3), + TestCase("BADANA", "ANADA", 3), + TestCase("BADANA", "CANADAS", 3), + TestCase("a1a234a5aaaa6", "A1AAAA234AAA56AAAAA", 6), + TestCase("123x", "123", 3), + TestCase("12x3x", "123", 3), + TestCase("1x2x3x", "123", 3), + TestCase("x1x2x3x", "123", 3), + TestCase("x12x3x", "123", 3)}; +} + +void test_longest_common_string_length() { + for (const auto& cur_tc : get_test_cases()) { + assert(longest_common_string_length(cur_tc.str_a, cur_tc.str_b) == + cur_tc.common_string_len); + } +} + +void test_longest_common_string_length_is_symmetric() { + for (const auto& cur_tc : get_test_cases()) { + assert(longest_common_string_length(cur_tc.str_b, cur_tc.str_a) == + cur_tc.common_string_len); + } +} + +/** + * @brief reverses a given string + * @param in_str input string + * @return the string in which the characters appear in the reversed order as in + * in_str + */ +std::string reverse_str(const std::string& in_str) { + return {in_str.rbegin(), in_str.rend()}; +} + +void test_longest_common_string_length_for_reversed_inputs() { + for (const auto& cur_tc : get_test_cases()) { + assert(longest_common_string_length(reverse_str(cur_tc.str_a), + reverse_str(cur_tc.str_b)) == + cur_tc.common_string_len); + } +} + +int main() { + test_longest_common_string_length(); + test_longest_common_string_length_is_symmetric(); + test_longest_common_string_length_for_reversed_inputs(); + return 0; }