Содержательно, правило корректного веса утверждает, что стековое выражение корректно тогда и только тогда, когда в нем самом и в каждом из его подвыражений имеется не меньше операций
Интуитивно сформулированное правило выглядит верным, но нам следует все же доказать, что оно имеет место. Удобно ввести еще одно вспомогательное правило и одновременно доказывать справедливость обоих этих правил:
Правило нулевого веса
Пусть e - это правильно построенное и корректное стековое выражение, не содержащее item или empty. Тогда empty (e) истинно тогда и только тогда, когда вес e равен 0.
Доказательство использует индукцию по уровню вложенности (максимальному числу вложенных пар скобок) выражения. Для удобства ссылок напомним аксиомы, относящиеся к функции
Аксиомы стека
Для всех x: G, s: STACK [G]
[x]. (A3) empty (new)
[x]. (A4) not empty (put (s, x))
При уровне вложенности 0 (без скобок) выражение e должно совпадать с
Индукционный шаг: предположим, что оба правила выполняются для всех выражений с уровнем вложенности не более
E1 · e = put (s, x)
E2 · e = remove (s)
где
В случае E1, поскольку
В случае E2 выражение
EB1 _ s и все его подвыражения являются корректными.
EB2 _ not empty (s) (это предусловие для функции remove).
По предположению индукции условие EB2 означает, что вес
remove (put (stack_expression, g_expression)),
которое по аксиоме A2 можно сократить просто до
Это доказательство попутно показывает, что во всяком правильно построенном выражении, не содержащем функций-запросов
put (remove (remove (put (put (remove (put (put (new, x1), x2)), x3), x4))), x5)
имеет то же значение, что и каноническая форма:
put (put (new, x1), x5).
Давайте дадим этому механизму имя и приведем его определение:
Правило канонического сокращения
Юрий Викторович Щербатых , Вильям Л Саймон , Наталья Владимировна Макеева , Нора Робертс , Вильям Саймон
Зарубежная компьютерная, околокомпьютерная литература / ОС и Сети, интернет / Короткие любовные романы / Психология / Прочая справочная литература / Образование и наука / Книги по IT / Словари и Энциклопедии