两个字符串的删除操作(动态规划—最长公共子序列)

x33g5p2x  于2021-09-25 转载在 其他  
字(0.4k)|赞(0)|评价(0)|浏览(425)

时间复杂度:O(nm)
空间复杂度:O(nm)

  1. class Solution {
  2. public:
  3. int minDistance(string word1, string word2) {
  4. int maxlen[555][555];
  5. int n=word1.length(),m=word2.length();
  6. for(int i=0;i<=m;i++)
  7. maxlen[0][i]=0;
  8. for(int i=0;i<=n;i++)
  9. maxlen[i][0]=0;
  10. for(int i=1;i<=n;i++){
  11. for(int j=1;j<=m;j++){
  12. if(word1[i-1]==word2[j-1]){
  13. maxlen[i][j]=maxlen[i-1][j-1]+1;
  14. }else{
  15. maxlen[i][j]=max(maxlen[i-1][j],maxlen[i][j-1]);
  16. }
  17. }
  18. }
  19. return n+m-maxlen[n][m]-maxlen[n][m];
  20. }
  21. };

相关文章