//
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];
}
}