I’ve been researching on finding an efficient solution to this. I’ve looked into diffing engines (google’s diff-match-patch, python’s diff) and some some longest common chain algorithms.
I was hoping on getting you guys suggestions on how to solve this issue. Any algorithm or library in particular you would like to recommend?
I don’t know what “longest common [[chain? substring?]]” has to do with “percent difference”, especially after seeing in a comment that you expect a very small % difference between two strings that differ by one character in the middle (so their longest common substring is about one half of the strings’ length).
Ignoring the “longest common” strangeness, and defining “percent difference” as the edit distance between the strings divided by the max length (times 100 of course;-), what about:
The Levenshtein function is from Stavros’ blog. The result in this case would be 5.26 (percent difference).