Задание.

- задан массив символов, элементы которого должны быть введены с
клавиатуры;
- результатом работы программы поиска является либо строка
'элемент найден', либо 'элемент не найден';
- символ для поиска должен вводиться с клавиатуры;
- результат программы сортировки - исходный и отсортированный
массивы;
- количество элементов в массиве не менее 10.


Алгоритм: Поиск с алфавитной индексацией (количество символов в 1-ой строке: 3)


Поиск с алфавитной индексацией. Данный алгоритм налагает дополнительное ограничение - таблица должна быть отсортирована алгоритмом с алфавитной индексацией, т.е. строки, начинающиеся с одного и того же символа, должны быть сгруппированы и должен быть создан массив входов в таблицу. Поиск складывается из следующих шагов:
- из ключа поиска выделяется первый символ и преобразуется в номер (индекс) элемента массива входов;
- из заданного предыдущим шагом элемента массива входов
извлекается номер первой строки из группы начинающихся с данного
символа строк;
- выполняется линейный поиск в заданной группе строк.


Вот, что у меня получилось. Помогите исправить/дополнить.


program rq;
var
  a:array[1..26]of integer;
  b:array[1..5]of string;
  b1:array[1..5]of string;
  s,key,y,w,q:string;
  i,j,k,l,t,ind,x,c,n,p:integer;
  f,z:char;
begin
  writeln('Vvedite massiv');
  for j:=1 to 5 do
  begin
     write ('b[',j,']=');
     readln (b[j]);
  end;

  l:=1;
  for j:=1 to 5 do
  begin
    s:=b[j];
    f:=s[1];
    i:=ord(f)-ord('a')+1;
    if (a[i]=0) then
    begin
       a[i]:=l;
       b1[l]:=b[j];
    end
    else
    begin
       n:=a[i];
       for k:=5 downto n do
       begin
          if k=5 then q:=b1[5]
          else b1[k+1]:=b1[k];
       end;

       for p:=1 to 26 do
       begin
          if (a[p]>n) then a[p]:=a[p]+1;
       end;
       b1[n]:=b[j];
    end;
    l:=l+1;
  end;

  for j:=1 to 5 do
  writeln (b1[j]);

  writeln ('vvedite iskomoe slovo');
  readln (key);
  z:=key[1];
  ind:=ord(z)-ord('a')+1;
  x:=a[ind];
  for c:=x to 5 do
  begin
    y:=b1[c];
    if y=key then
    begin
       writeln ('Iskomoe slovo');
       write (y);
    end;
  end;

  readln;

end.


М
Тэги! Правила раздела Задачи, п.2
Lapp