zoukankan      html  css  js  c++  java
  • 判断两个字符相似度

    #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

  • 相关阅读:
    selenium python 启动Chrome
    安装selenium python
    网络编程32
    动态生成验证码———MVC版
    C#之发送邮件【模板】+【封装】ZJ版
    【转】解读ASP.NET 5 & MVC6系列(1):ASP.NET 5简介
    Cache,MemCache,Application,Cookie等其它缓存汇总
    点击弹出li所在的序列号
    【转】js实现复制到剪贴板功能,兼容所有浏览器
    前端效果——持续更新。。。
  • 原文地址:https://www.cnblogs.com/liujie1111/p/4359649.html
Copyright © 2011-2022 走看看