edit distance

class Solution {
public:
    int minDistance(string word1, string word2) {
        // Start typing your C/C++ solution below
        // DO NOT write int main() function
        vector<vector<int> > f(word1.size()+1, vector<int>(word2.size()+1));
        
        f[0][0] = 0;
        for(int i = 1; i <= word2.size(); i++)
            f[0][i] = i;
        
        for(int i = 1; i <= word1.size(); i++)
            f[i][0] = i;
            
        for(int i = 1; i <= word1.size(); i++)
            for(int j = 1; j <= word2.size(); j++)
            {
                f[i][j] = INT_MAX;
                if (word1[i-1] == word2[j-1]) 
                    f[i][j] = f[i-1][j-1];
                
                f[i][j] = min(f[i][j], f[i-1][j-1] + 1); //replace
                f[i][j] = min(f[i][j], min(f[i-1][j], f[i][j-1]) + 1); //delete or insert               
            }
            
        return f[word1.size()][word2.size()];
    }
};

 

posted on 2013-09-08 11:19  jumping_grass  阅读(211)  评论(0)    收藏  举报

导航