Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.12.02;
Скачать: CL | DM;

Вниз

поиск array[1..n] of byte в array[1..m] of byte   Найти похожие ветки 

 
Кокандокало   (2002-11-20 20:48) [0]

Привет, Мастера!
Предложите алгоритм поиска array[1..n] of byte в array[1..m] of byte, где n < m
Желательно возвратить смещение =)


 
TTCustomDelphiMaster ©   (2002-11-20 22:02) [1]

var
A: array [2..15] of byte;
SubA: array [1..3] of byte;
i, j: integer;
begin
A[4] := 4;
A[5] := 5;
A[6] := 4;
A[7] := 5;
A[8] := 4;
SubA[1] := 4;
Suba[2] := 5;
SubA[3] := 4;

i := Low(A);
j := Low(SubA);
while i<=High(A)-High(SubA)+Low(SubA) do
begin
if A[i]=SubA[j] then
begin
inc(j);
if j>High(SubA) then
begin
dec(i, High(SubA)-Low(SubA));
j := Low(SubA);
ShowMessage("Index = " + inttostr(i));
end;
end;
inc(i);
end;
end;


 
TTCustomDelphiMaster ©   (2002-11-20 22:50) [2]

Поправочка

while i<=High(A)-High(SubA)+Low(SubA) do
begin
if A[i]=SubA[j] then
begin
inc(j);
if j>High(SubA) then
begin
dec(i, High(SubA)-Low(SubA));
j := Low(SubA);
ShowMessage("Index = " + inttostr(i));
end;
end
else
j := Low(SubA);
inc(i);
end;


 
Кокандокало   (2002-11-21 12:01) [3]

дык не пашет =(((
Вот в моем исполнении тоже самое и не пашет...

function findArr(A,SubA: array of byte):integer;
var
i,j: integer;
begin
i := Low(A);
j := Low(SubA);
while i<=High(A)-High(SubA)+Low(SubA) do
begin
if A[i]=SubA[j] then
begin
inc(j);
if j>High(SubA) then
begin
dec(i, High(SubA)-Low(SubA));
j := Low(SubA);
ShowMessage("Index = " + inttostr(i));
findArr := i;
Exit;
end;
end
else
j := Low(SubA);
inc(i);
end;
ShowMessage("Not found");
end;

Может кнут у кого под рукой есть? там алгоритм поиска подстроки в строке есть.. может кто посмотрит?



Страницы: 1 вся ветка

Текущий архив: 2002.12.02;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.2 c
7-4641
SanSoft
2002-09-25 14:10
2002.12.02
что запустило программу


1-4308
AlexeyMir
2002-11-21 13:44
2002.12.02
WindowsXP


3-4195
Pegas
2002-11-13 15:12
2002.12.02
InterBase после удаления даных база не уменьшается!


1-4446
Mad_Ghost
2002-11-20 10:45
2002.12.02
как изменить ширину колонки в DBGrid StringGrid???


1-4410
Separator
2002-11-20 13:10
2002.12.02
Прикол с TThread