Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 20.09.2009
Сообщений: 44
1

Проверить правильность расстановки скобок

07.01.2010, 17:26. Показов 1456. Ответов 3
Метки нет (Все метки)

Дано арифметическое выражение, содержащее три вида скобок "(","[","{". Проверить правильность расстановки скобок, если какая-то скобка не имеет парной, напечатать, какая именно. Применяя рекурсии.
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.01.2010, 17:26
Ответы с готовыми решениями:

Проверить правильность расстановки скобок.
Дана строка символов, содержащая круглые скобки.Проверить правильность расстановки скобок.

Проверить правильность расстановки операторных скобок 'begin' и 'end'
Доброго времени суток )))) Помогите пожалуйста : проверка правильности расстановки операторных...

1.В заданном предложении проверить парность расстановки круглых скобок. Вложение скобок допускается. 2. Заданы два массива A и B одинаковой размерност
1.В заданном предложении проверить парность расстановки круглых скобок. Вложение скобок...

Проверить баланс расстановки скобок в строке
Дана строка, содержащая несколько круглых скобок. Если скобки расставлены правильно (то есть каждой...

3
3065 / 725 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
07.01.2010, 18:45 2
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Ну вот как-то так у меня получилось:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
Program xa;
uses
  crt;
 
function prov(s:string;ch,ch1:char;pos:byte;kol:integer):integer;
begin
  if s[pos]=ch then
    inc(kol);
  if s[pos]=ch1 then
  if kol>0 then
    dec(kol)
  else
  begin
    prov:=-1;
    exit
  end;
  inc(pos);
  if pos<length(s)+1 then
    prov:=prov(s,ch,ch1,pos,kol)
  else
    prov:=kol;
end;
var
  s:string;
  ch,ch1:char;
begin
  clrscr;
  Writeln('Vvedute ctpoky');
  readln(s);
  clrscr;
  Writeln('Vvedute ckobky kotopa9 Vas unTepeCyet "(,{,[":');
  readln(ch);
  case ch of
   '(':ch1:=')';
   '[':ch1:=']';
   '{':ch1:='}';
  end;
  case prov(s,ch,ch1,1,0) of
    0:Writeln('Ckobku pacctavleHbl pravul''no.');
    -255..-1:Writeln('Ckobku pacctavleHbl Nepravul''no.');
    1..255:Writeln('Ckobku pacctavleHbl Nepravul''no.');
  end;
  readkey;
end.
2
1 / 1 / 0
Регистрация: 20.09.2009
Сообщений: 44
07.01.2010, 18:58  [ТС] 3
Спасибо большое за помощь
0
3065 / 725 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
07.01.2010, 19:12 4
Хотелось бы мне прокомментировать программу, решил сделать именно так, я говорю про передачу строки функции, из-за того, что у нас максимальная вложенность получится 255 и 255 копий размером(1 string; 2 char; 1 byte; 1 integer)- это не очень критично, даже для паскаля...
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.01.2010, 19:12

В заданном предложении проверить парность расстановки круглых скобок
1.Заданы два массива A и B одинаковой размерности. Вычислить массив , компоненты которого...

РАССТАНОВКИ СКОБОК
&quot;&quot; &quot;&quot; Работа со скобками &quot;&quot; &quot;как переделать код чтобы в такого выражения )5+4( результат...

Проверка правильности расстановки скобок
Преподаватель поставила сегодня в тупик вопросом. Как с помощью оператора выбора Case проверить...

Ввести произвольный текст. Проверить, в заданном тексте количество открытых скобок равно количеству закрытых скобок.
Помогите сделать задачу: Ввести произвольный текст. Проверить, в заданном тексте количество...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru