583 兩個字串的刪除操作

2022-05-19 16:52:55 字數 823 閱讀 2139

給定兩個單詞 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步數,每步可以刪除任意乙個字串中的乙個字元。

示例 1:

輸入:"sea", "eat"

輸出:2

解釋:第一步將"sea"變為"ea",第二步將"eat"變為"ea"

說明:給定單詞的長度不超過500。

給定單詞中的字元只含有小寫字母。

可以通過間接求兩個單詞的最長公共子串行求解,比如示例中"sea"和"eat"的最長公共子串行是"ea",長度為2。

不難看出  answer = lengthofword1 - 2 + lengthofword2 - 2 

lcs問題可以使用動態規劃求解,具體的實現思路強烈推薦學習《演算法導論(第三版)》中15.4一講。

1

class

solution , b[n][n] = ;67

//string backstr = "";

8int lcs(string &x, string &y)925

else

2632

33else

if(c[i - 1][j] < c[i][j - 1

])34

3839

else

40 44}

45}46}

47}4849

return lenx + leny - 2 *c[lenx][leny];50}

51 };

583 兩個字串的刪除操作

給定兩個單詞 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步數,每步可以刪除任意乙個字串中的乙個字元。示例 1 說明 1.給定單詞的長度不超過500。2.給定單詞中的字元只含有小寫字母。為了求得最少刪除次數,我們可以求出串 s1和串 s2最長公共子串行,我們記為 ...

583 兩個字串的刪除操作

題目描述 給定兩個單詞 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步數,每步可以刪除任意乙個字串中的乙個字元。解題思路 動態規劃,和最長公共子串行相似,根據當前結尾的兩個字元是否相等選擇不同的轉移方式,如下 class solution def mindista...

583 兩個字串的刪除操作

題目描述 給定兩個單詞 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步數,每步可以刪除任意乙個字串中的乙個字元。示例 輸入 sea eat 輸出 2 解釋 第一步將 sea 變為 ea 第二步將 eat 變為 ea 給定單詞的長度不超過500。給定單詞中的字元只含...