Python基於動態規划算法計算單詞距離

來源:互聯網
上載者:User
本文執行個體講述了Python基於動態規划算法計算單詞距離。分享給大家供大家參考。具體如下:

#!/usr/bin/env python#coding=utf-8def word_distance(m,n):  """compute the least steps number to convert m to n by insert , delete , replace .  動態規划算法,計算單詞距離  >>> print word_distance("abc","abec")  1  >>> print word_distance("ababec","abc")  3  """  len_1=lambda x:len(x)+1  c=[[i] for i in range(0,len_1(m)) ]  c[0]=[j for j in range(0,len_1(n))]  for i in range(0,len(m)):  #  print i,' ',    for j in range(0,len(n)):      c[i+1].append(        min(          c[i][j+1]+1,#插入n[j]          c[i+1][j]+1,#刪除m[j]          c[i][j] + (0 if m[i]==n[j] else 1 )#改        )      )  #    print c[i+1][j+1],m[i],n[j],' ',  #  print ''  return c[-1][-1]import doctestdoctest.testmod()raw_input("Success!")

希望本文所述對大家的Python程式設計有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.