#region 判斷兩個字符相似度
//公式:l = q/(q+r+s);
private string Similarity(string a, string b)
{
string a1 = "";
string b1 = "";
//消除重復
for(int i=0;i<a.Length;i++)
{
string emtpy=a.Substring(i,1).ToString();
if(a1.Length==0)
{
a1=emtpy;
}
if(a1.IndexOf(emtpy,0)<0)
{
a1+=emtpy;
}
}
//消除重復
for (int i = 0; i < b.Length; i++)
{
string emtpy = b.Substring(i, 1).ToString();
if (b1.Length == 0)
{
b1 = emtpy;
}
if (b1.IndexOf(emtpy, 0) < 0)
{
b1 += emtpy;
}
}
//計算相似度
if (a1.Length >= b1.Length)
{
int q = 0;
for (int i = 0; i < b1.Length; i++)
{
for (int j = 0; j < a1.Length; j++)
{
if (b1.Substring(i, 1).ToString() == a1.Substring(j, 1).ToString())
{
q += 1;
}
}
}
System.Globalization.NumberFormatInfo provider = new System.Globalization.NumberFormatInfo();
provider.PercentDecimalDigits = 2;//小數點保留幾位數.
provider.PercentPositivePattern = 1;//百分號出現在何處.
double result = (double)q / (a1.Length + b1.Length - q);//一定要用double類型.
return result.ToString("P", provider);
}
else
{
int q = 0;
for (int i = 0; i < a1.Length; i++)
{
for (int j = 0; j < b1.Length; j++)
{
if (a1.Substring(i, 1).ToString() == b1.Substring(j, 1).ToString())
{
q += 1;
}
}
}
System.Globalization.NumberFormatInfo provider = new System.Globalization.NumberFormatInfo();
provider.PercentDecimalDigits = 2;//小數點保留幾位數.
provider.PercentPositivePattern = 1;//百分號出現在何處.
double result = (double)q / (a1.Length + b1.Length - q);//一定要用double類型.
return result.ToString("P", provider);
}
}
#endregion
裝載http://blog.sina.com.cn/s/blog_5f254b8a0100t4hy.html
參考文章:http://www.360doc.com/content/09/0201/10/96202_2430832.shtml