比较字符串列表和字符串以查找连续字符匹配的数量
本文关键字:字符串 字符 连续 列表 查找 比较 | 更新日期: 2023-09-27 18:09:44
我确信这之前已经完成了,但我真正想做的是有一个方法,找到一个字符串字符的连续匹配,在一组多个字符串内,任何匹配小于1个字符匹配,不计算。(最少2).
如果要测试的字符串是"xx Audible 5",则结果如下
- Audible xxx-xxx-5051 NJ -----结果:10(匹配'Audible'和'xx')
- yy Audible -----结果:8 (Audible)
- Audible 5 xy -----结果:9(空格计数,所以匹配是Audible 5)
- Audible.com 5 -----结果:7
试试这个。这没有经过优化,但是效果很好
static int FindMatch(string text, string pattern)
{
var total = 0;
for (int i = 0; i < pattern.Length; i++)
{
var max = 0;
for (int j = 2; j <= pattern.Length - i; j++)
{
var temp = pattern.Substring(i, j);
if (text.Contains(temp))
if (max < temp.Length)
max = temp.Length;
}
total += max;
if (max > 0)
i += max-1;
}
return total;
}
FindMatch("Audible xxx-xxx-5051 NJ", "xx Audible 5");
返回10FindMatch("yy Audible", "xx Audible 5");
返回8-
FindMatch("Audible 5 xy", "xx Audible 5");
返回9 -
FindMatch("Audible.com 5", "xx Audible 5");
也返回9而不是7,因为正如我在这个例子中所理解的那样,空格5"5" 将失败