Problem 93. Calculate the Levenshtein distance between two strings
The Levenshtein distance between two strings is defined as the minimum number of edits needed to transform one string into the other, with the allowable edit operations being insertion, deletion, or substitution of a single character.
For example, the Levenshtein distance between "kitten" and "sitting" is 3, since the following three edits change one into the other, and there is no way to do it with fewer than three edits:
 kitten => sitten  (substitution of 's' for 'k')
 sitten => sittin  (substitution of 'e' for 'i')
 sittin => sitting (insert 'g' at the end).
So when
 s1 = 'kitten'
and
 s2 = 'sitting'
then the distance d is equal to 3.
Solution Stats
Problem Comments
- 
		3 Comments
		jj L
    	on 9 Aug 2018
	
	
  	Good question
		Stephan Allgeier
    	on 10 Jan 2020
	
	
  	I really like this problem. So far, this is the one I had to think about most. Mostly because the straight-forward recursive implementation is simply not feasible for longer inputs.
		Roie Knaanie
    	on 15 Oct 2022
	
	
  	This question is a good example of using a bottom-up dynamic programming algorithm.
Solution Comments
Show commentsProblem Recent Solvers1479
Suggested Problems
- 
         
         1363 Solvers 
- 
         How to find the position of an element in a vector without using the find function 2774 Solvers 
- 
         Given an unsigned integer x, find the largest y by rearranging the bits in x 1928 Solvers 
- 
         
         2224 Solvers 
- 
         
         8012 Solvers 
More from this Author96
Problem Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!