#判斷兩個(gè)字符串從不相同到相同最少需要幾次變化(增加字符、刪除字符、替換字符)
def levenshtein_distance(s, t)
m = s.length
n = t.length
return m if n == 0
return n if m == 0
#初始化一個(gè)二維數(shù)組,行數(shù)是s字符串的長(zhǎng)度+1,列數(shù)是t字符串的長(zhǎng)度+1
d = Array.new(m+1) {Array.new(n+1)}
#將第一行和第一列的值初始化。
#d[m][0]表示從一個(gè)空字符串變成與s相等的字符串最少需要幾步
#d[0][n]表示從一個(gè)空字符串變成與t相等的字符串最少需要幾步
#d[0][0]表示兩個(gè)空字符串需要0步就相等了
(0..m).each {|i| d[i][0] = i}
(0..n).each {|j| d[0][j] = j}
#至此,數(shù)據(jù)初始化結(jié)束,因?yàn)槎嗔艘恍泻鸵涣?,每一個(gè)交叉點(diǎn),比如d[i][j]的左方向、上方向以及左上角都有一個(gè)值,
# d.each {|ele| p ele}
#開始遍歷
(1..n).each do |j|
(1..m).each do |i|
#判斷同位置的字符是否相同,相同的話,就將左上角位置的值寫入。表示本次比較并不需要任何操作
if s[i-1] == t[j-1] # adjust index into string
d[i][j] = d[i-1][j-1] # no operation required
else
#如果不相同,則計(jì)算刪除字符串、增加字符串、替換字符串經(jīng)過的步數(shù)。
d[i][j] = [ d[i-1][j]+1, # deletion 刪除
d[i][j-1]+1, # insertion 增加
d[i-1][j-1]+1, # substitution 替換
].min
end
end
end
#d[m][n]的值越大,表示兩個(gè)字符串變成相同所需要經(jīng)過的步數(shù)越多,意味著兩個(gè)字符串越不相似
d[m][n]
end
判斷兩個(gè)字符串從不相同到相同最少需要幾次變化
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 成長(zhǎng)記錄-連載(三十六) ——我的第一篇五千字長(zhǎng)文,說了什么,你一定想不到 并不是不想每天寫公眾號(hào),而是之前思考怎...
- 【蝴蝶效應(yīng)】 蝴蝶效應(yīng):上個(gè)世紀(jì)70年代,美國(guó)一個(gè)名叫洛倫茲的氣象學(xué)家在解釋空氣系統(tǒng)理論時(shí)說,亞馬遜雨林一只蝴蝶...
- 寫在畢業(yè)那年,紀(jì)念我們的青春 其實(shí) 我舍不得的 也只不過就是那株開花的梔子 從來不敢奢求 誰(shuí)能給我 永不泛黃的潔...
- 兔子的復(fù)活節(jié):必須阿瑪尼....我都能寫一封阿瑪尼種草日記 我喜歡馮沁:蘇酷粉底啊 超級(jí)順滑 出點(diǎn)油以后巨無霸好看...