// namespace SafeCampus.Core.Utils; /// /// 密码相关通用类 /// public class PwdUtil { /// /// 密码相似度 /// /// /// /// public static double Similarity(string oldPassword, string newPassword) { var editDistance = LevenshteinDistance(oldPassword, newPassword); var similarity = 1.0 - editDistance / (double)Math.Max(oldPassword.Length, newPassword.Length); return similarity * 100; } /// /// 计算莱文斯坦距离算法 /// /// /// /// public static int LevenshteinDistance(string s1, string s2) { var distance = new int[s1.Length + 1, s2.Length + 1]; for (var i = 0; i <= s1.Length; i++) { distance[i, 0] = i; } for (var j = 0; j <= s2.Length; j++) { distance[0, j] = j; } for (var i = 1; i <= s1.Length; i++) { for (var j = 1; j <= s2.Length; j++) { var cost = s1[i - 1] == s2[j - 1] ? 0 : 1; distance[i, j] = Math.Min(Math.Min(distance[i - 1, j] + 1, distance[i, j - 1] + 1), distance[i - 1, j - 1] + cost); } } return distance[s1.Length, s2.Length]; } }