⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 boyer_moore_string_matching.m

📁 数据挖掘经典算法matlab实现
💻 M
字号:
function sh = Boyer_Moore_String_Matching(text, x)

% Boyer-Moore string matching: Find the location of the string x in text 'text'
%
% Inputs:
%	text				- Text vector
%	x					- Search string
%
% Output:
%	sh					- Locations of the string

n	= length(text);
m	= length(x);
s	= 0;
sh	= [];

while (s <= n - m),
   j = m;
   while ((j > 0) & (x(j) == text(s+j))),
      j = j - 1;
   end
   if (j == 0),
      disp(['The pattern occurs at shift ' num2str(s+1)])
      sh(end+1) 	= s+1;
      s				= s + G(x, 0);
   else
      s				= s + max(G(x, j), j - F(x, text(s + j)));
   end
end
%END

function s = G(x, m)
%Good suffix function: Find the leftmost occurence of the 'm' characters
n = length(x);

s = 0;
for i = n-2*m+1:-1:1,
   if strcmp(x(end-m+1:end), x(i:i+m-1)),
      s = i;
      break
   end
end

function s = F(x, c)
%Last occurrence function
n = length(x);

s = 0;
for i = n:-1:1,
   if (x(i) == c),
      s = i;
   end
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -