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) 收藏 举报
浙公网安备 33010602011771号