zoukankan      html  css  js  c++  java
  • C# 字符串相似度算法

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Windows.Forms;

    namespace 字符串相似度
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }

            ******* void button1_Click(object sender, EventArgs e)
            {
                String str1 = textBox1.Text;
                String str2 = textBox2.Text;
                label3.Text = get_semblance_By_2words(str1, str2);
            }

            public static string get_semblance_By_2words(string word1, string word2)
            {
                int re = 0;
                int maxLength;
                int i, l;
                List<string> tb1 = new List<string>();
                List<string> tb2 = new List<string>();
                i = 0;
                l = 1;
                maxLength = word1.Length;
                if (word1.Length < word2.Length)
                    maxLength = word2.Length;
                while (l <= word1.Length)
                {
                    while (i < word1.Length - 1)
                    {
                        if (i + l > word1.Length)
                            break;
                        tb1.Add(word1.Substring(i, l));
                        i++;
                    }
                    i = 0;
                    l++;
                }

                i = 0;
                l = 1;

                while (l <= word2.Length)
                {
                    while (i < word2.Length - 1)
                    {
                        if (i + l > word2.Length)
                            break;
                        tb2.Add(word2.Substring(i, l));
                        i++;
                    }
                    i = 0;
                    l++;
                }
                foreach (string subStr in tb1)
                {
                    int tempRe = 0;
                    if (tb2.Contains(subStr))
                    {
                        tempRe = subStr.Length * 100 / maxLength;
                        if (tempRe > re)
                            re = tempRe;
                        if (tempRe == 100)
                            break;
                    }
                }
                return re.ToString() + "%";
            }

        }
    }
     

    源代码下载

  • 相关阅读:
    UI设计师需要熟记的45个快捷键Windows、Mac
    手把手教你制作好莱坞大片级场景——宇宙猫
    关于功能图标的绘制方法!
    设计师该如何把简历写好?
    PS合成的5个要点:场景、对比、氛围、模糊、纹理
    UI设计工资有多高?怎么快速拿高薪?
    19. Remove Nth Node From End of List
    18. 4Sum
    17. Letter Combinations of a Phone Number
    16. 3Sum Closest
  • 原文地址:https://www.cnblogs.com/hackpig/p/1668492.html
Copyright © 2011-2022 走看看