名称相似匹配度算法
来源:互联网 发布:手机免费听歌软件 编辑:程序博客网 时间:2024/04/18 16:33
public class Levenshtein { public static void main(String[] args) { //要比较的两个字符串 String str1 = "今天星期四"; String str2 = "今天是星期四"; levenshtein(str1,str2); str1 = "今天星期四"; str2 = "今天星期(四)"; levenshtein(str1,str2); str1 = "今天星期四"; str2 = "今天星期四223"; levenshtein(str1,str2); str1 = "今天星期四"; str2 = "今天新期四"; levenshtein(str1,str2); } public static void levenshtein(String str1,String str2) { //计算两个字符串的长度。 int len1 = str1.length(); int len2 = str2.length(); //建立上面说的数组,比字符长度大一个空间 int[][] dif = new int[len1 + 1][len2 + 1]; //赋初值,步骤B。 for (int a = 0; a <= len1; a++) { dif[a][0] = a; } for (int a = 0; a <= len2; a++) { dif[0][a] = a; } //计算两个字符是否一样,计算左上的值 int temp; for (int i = 1; i <= len1; i++) { for (int j = 1; j <= len2; j++) { if (str1.charAt(i - 1) == str2.charAt(j - 1)) { temp = 0; } else { temp = 1; } //取三个值中最小的 dif[i][j] = min(dif[i - 1][j - 1] + temp, dif[i][j - 1] + 1, dif[i - 1][j] + 1); } } //计算相似度 float similarity =1 - (float) dif[len1][len2] / Math.max(str1.length(), str2.length()); System.out.println("字符串\""+str1+"\"与\""+str2+"\"的比较;"+"差异步骤:"+dif[len1][len2]+";相似度:"+similarity); } //得到最小值 private static int min(int... is) { int min = Integer.MAX_VALUE; for (int i : is) { if (min > i) { min = i; } } return min; } }
这是个相似匹配度的算法,是按照顺序比较出来的,但是我感觉缺点也很明显,比如我要匹配123和1332,匹配度是0.5,将33直接扔掉了,而且对于Levenshtein算法算法我表示很迷惑唉
- 名称相似匹配度算法
- 中文相似度匹配算法
- 中文相似度匹配算法
- 通用算法-sql相似度模糊匹配
- 文本相似度匹配
- 图片尺寸相似度匹配
- SimilarityUtil相似度匹配
- OpenCV 图像相似度匹配之感知哈希算法
- 匹配字符串相似度算法(各个语言版本)
- 计算字符匹配相似度
- 图片相似度算法
- 文本相似度算法
- 文本相似度算法
- 字符串相似度算法
- 字符串相似度算法
- 文本相似度算法
- 文本相似度算法
- 文本相似度算法
- form中的input的redonly和disable区别
- 13周项目4
- C++ primer 第二章习题
- jquery的动画
- DNS解析过程详解
- 名称相似匹配度算法
- Solr部署配置(三)实时检索接口
- ntp服务器配置for linux
- oracle学习笔记2
- poj2449-A*算法+优先队列+第k最短路
- 众数问题分析
- JSTL JSP标准标签库(四)
- 关于l ibrary not found for -lz.1.2.3 编译错误
- bzip2压缩实例