Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Object Pascal: кроссплатформенные технологии > Скобки


Автор: SapFira 23.4.2009, 10:33
Программа проверяет расстановку правильности скобок с помощью занесения в стек, но проверяет почему то не верно,а вроде все так, посмотрите ошибка где может или по другому реализовать нужно??

Код

Program Skobki;
Type
  EXST = ^ST;
  ST = record
       Data : char;
       Next : EXST;
  end;
Var
  a : string;
  f : boolean;
  i : integer;
Procedure writeStack(Var x1 : EXST; c : char);
Var
  u : EXST;
Begin
  new(u); {создание нового элемента стека}
  u^.Data := c;
  u^.Next := x1; 
  x1 := u; {созданный элемент определить как вершину стека}
End;
Procedure DelStack(Var x1 : EXST); {процедура удаления верхнего элемента стека}
Var
  u : EXST;
Begin
  u := x1;
  x1 := x1^.Next;
  dispose(u);
End;
Procedure Solve(a : string); {проверка правильности расстановки скобок}
Var
  Stack : EXST;
Begin
  Stack := Nil;
  i := 1;
  while (i<=Length(a)) and f do
    begin
      if (a[i]='(') or (a[i]='{') or (a[i]='[')
        then
          writeStack(Stack , a[i])
        else 
          if (a[i]=')') or (a[i]='}') or (a[i]=']')
            then
              if (Stack <> Nil) And (Ord(a[i]) - Ord(Stack ^.Data) <= 2)
                then
                  DelStack(Stack)
                else
                  f := False;
      Inc(i);
  end;
end;
Begin
  writeln('Введите строку');
  readln(a);
  f := True;
  if a<>''
    then
      begin
        Solve(a);
        if f
          then
            writeln('Все скобки расставлены верно')
          else
            writeln('Скобка ',a[i-1],' закрыта преждевременно');
      end
    else
      writeln('Строка пуста');
  readln;
End.


Автор: volvo877 23.4.2009, 15:21
SapFira, в условии
Код
if (Stack <> Nil) And (Abs(Ord(a[i]) - Ord(Stack^.Data)) <= 2)
 не хватало модуля... Понимаешь, почему выдавало неверный ответ?

Автор: SapFira 23.4.2009, 15:27
Все равно если ввести строку: ([] 
то пишет что скобки все верны, а это неправильно...

Автор: volvo877 23.4.2009, 16:45
В конце надо проверять, остался ли стек пустым. Если нет - значит, в исходной строке не хватает закрывающих скобок:
Код
Procedure Solve(a : string);
Var
  Stack : EXST;
Begin
  Stack := Nil;
  i := 1;
  while (i<=Length(a)) and f do
    begin
      if (a[i]='(') or (a[i]='{') or (a[i]='[')
        then
          writeStack(Stack , a[i])
        else
          if (a[i]=')') or (a[i]='}') or (a[i]=']')
            then
              if (Stack <> Nil) And (Abs(Ord(a[i]) - Ord(Stack ^.Data)) <= 2)
                then
                  DelStack(Stack)
                else
                  f := False;
      Inc(i);
  end;
  f := f and (stack = nil); { <--- Вот проверка на пустоту стека }
end;

Автор: SapFira 23.4.2009, 16:53
Спасибо, вроде работает, теперь понятно.  А не подскажите еще как сделать сохранение в файл,например этой строки и результатом:верно или не верно расставлены??

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)