Потопахин Виталий Валерьевич 3 Задачи прикладного характера по информатике 3 миф-2, №2, 2000 8 Потопахин Виталий Валерьевич 8 решение

Вид материалаРешение

Содержание


ЗАДАЧИ ЗАОЧНОЙ ОЛИМПИАДЫ ПО информатике для 8 – 10 классов
1 кривая второго порядка – 1 1
МИФ-2, №3, 2002 Потопахин Виталий Валерьевич Математическая логика (ЧАСТЬ 1)
Фрукты могут расти на деревьях.
2. В одной из этих комнат находится принцесса; кроме того, в одной из этих комнат сидит тигр.
Понятие высказывания
Сложные высказывания. Логические операции
Помидор может быть красным и помидор может быть круглым.
Дизъюнктивная нормальная форма.
Конъюнктивная нормальная форма.
Abc) (abc) (abc)
Подобный материал:
1   ...   6   7   8   9   10   11   12   13   ...   21
^

ЗАДАЧИ ЗАОЧНОЙ ОЛИМПИАДЫ ПО информатике для 8 – 10 классов


Здесь приведены тексты задач заочной олимпиады по информатике. Задания общие и для восьмиклассников и для десятиклассников. Вы должны самостоятельно выбрать те задачи, которые можете решить. Оформить подробные решения и отправить их в адрес редакции журнала. Ничего страшного, если вам удастся решить только одну задачу. Можно присылать также частичные и неполные решения (когда рассмотрены не все случаи или частный случай). Те из вас, кто получит приглашения на летнюю сессию в августе месяце, могут не отправлять решения в Хабаровск, а привезти их с собой. Желаем вам успехов.

  1. Построить кривую по следующему правилу: на отрезке АВ как на диаметре строится полуокружность АВ. Далее отрезок АВ делится пополам точкой В´. на отрезке ВВ´ как на диаметре строится дуга ВВ´ с противоположной выпуклостью. Затем отрезок ВВ´ делится пополам точкой В´´. на отрезке В´В´´. На отрезке В´В´´ как на диаметре строится дуга В´В´´ и так далее.
  2. Натуральное число называется палиндромом, если он одинаково читается с обеих сторон.

Возьмем любое число, если оно не палиндром, то перевернем его и сложим с исходным, и так до тех пор, пока не получим палиндром. Для любого заданного числа определить число шагов до получения палиндрома.
  1. Построить кривую Коха.

Для ее построения берется отрезок (инициатор)


Д
алее инициатор заменяется на образующий элемент вида:

К
аждый отрезок заменяется на образующий элемент. И так далее.

  1. Кривая дракона строится следующим образом:

а) каждой кривой ставится в соотвествие последовательность 0 и 1 (1 – поворот налево, 0 – поворот направо)

б) последовательность первого уровня состоит из одной 1. Для построения формулы кривой следующего уровня ставим 1; слева от этой единицы записываем формулу кривой предыдущего уровня; справа от нее записываем формулу кривой предыдущего уровня, заменив в ней среднюю единицу на 0. Например:

кривая первого порядка – ^ 1

кривая второго порядка – 1 1 0

кривая третьего порядка – 1 1 0 1 1 0 0

Построить и изобразить кривую n-го порядка.

  1. На плоскости задано N вершин выпуклого многоугольника. Задана точка А вне многоугольника. Определите сколько вершин видно из точки А.
^

МИФ-2, №3, 2002

Потопахин Виталий Валерьевич

Математическая логика (ЧАСТЬ 1)


Это занятие посвящено важнейшему предмету для освоения искусства программирования – математической логике. Этот курс настолько важен, что время от времени, мы его повторяем, но каждый раз несколько иначе, поэтому он будет полезен и тем, кто займётся математической логикой впервые и тем, кто уже изучал этот материал в курсе физмат школы.

Данное изложение от всех предыдущих будет отличаться объемом, поэтому оно поделено на две части. В этом номере вашему вниманию предложена первая часть.

Что такое логический вывод?

Пусть дано два утверждения:
  1. ^ Фрукты могут расти на деревьях.
  2. Яблоко это фрукт.

Так как оба эти утверждения истинны, то можно сказать, что утверждение «Яблоки могут расти на деревьях» также истинно. Это третье утверждение никак не содержится в двух первых, оно из них следует. Или, иначе говоря, третье утверждение является логическим выводом из первых двух.

Это был простой пример. Сейчас рассмотрим пример посложнее. Попробуем решить задачу из книги профессора Р.М. Смаллиана, «Принцесса или тигр».

Условие. В этой задаче необходимо выяснить: в какой из двух комнат находится принцесса, а в какой тигр. На дверях каждой из комнат есть таблички с некоторыми утверждениями, кроме того, дополнительно известно, что на одной табличке написана правда, а на другой нет, но на какой правда, а на какой ложь не известно. И ещё известно, что в каждой комнате кто-то есть.

1. В этой комнате находится принцесса, а в другой комнате сидит тигр.

^ 2. В одной из этих комнат находится принцесса; кроме того, в одной из этих комнат сидит тигр.

Решение. Утверждения на табличках не могут быть одновременно истинными или ложными. Следовательно, возможны только две ситуации. Первая: первое истинно, а второе ложно и вторая: первое ложно, а второе истинно. Рассмотрим их.

Ситуация 1. Из истинности первого утверждения следует, что принцесса находится в первой комнате, а тигр во второй. В это же время из ложности второго утверждения следует, что нет комнаты, в которой находится принцесса и нет комнаты в которой сидит тигр. Следовательно, истинность первого утверждения и ложность второго невозможны одновременно.

Ситуация 2. Из истинности второго утверждения следует только то, что и тигр и принцесса имеются в наличии. Из ложности же первого следует, что принцесса находится во второй комнате, а тигр в первой. Анализируя вторую ситуацию, мы не получили противоречия, следовательно ситуация 2 и есть решение задачи.

Решение данной задачи есть пример более сложного рассуждения. Однако нетрудно заметить общий принцип. В этом рассуждении, так же как и в первом примере есть элементарные утверждения из истинности, которых следует истинность или ложность других утверждений. А цель логического вывода как раз и заключается в установлении истинности или ложности различных утверждений.

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

Остается выяснить, что такое правильный логический вывод. А это уже очень сложный вопрос. Чтобы на него ответить и нужна целая наука, называемая математической логикой. А сейчас нам нужно несколько определений.

^ Понятие высказывания

У всех утверждений, которые мы использовали выше в качестве примеров, есть одно общее свойство. Независимо от их смысла они могут быть либо истинными, либо ложными. Утверждения, обладающие таким свойством, называются высказываниями. Не всякое утверждение может быть высказыванием. К примеру, следующее утверждение: «Малахит самый красивый камень из всех известных самоцветов» высказыванием быть не может, так как это вопрос вкуса.

Бывают утверждения истинность или ложность, которых в принципе проверить можно, но только в принципе, реально же это невозможно. Например, невозможно проверить истинность следующего утверждения: «На планете Земля в настоящее время есть одно и только одно дерево, на котором растет ровно 10000 листьев». Теоретически это проверить можно, но только теоретически, так как для такой проверки придётся использовать слишком большое количество проверяющих, значительно большее чем проживает на планете людей.

Таким образом, математическая логика изучает только высказывания, и только то, как определять их истинность или ложность. Математическая логика не исследует смысл высказываний, из чего следует, что формулировка высказывания роли не играет и для высказывания достаточно ввести простое обозначение.

Собственно так и происходит. Высказывания обозначают просто буквами: А, В, С и т.д. и говорят о них только то, что они истинны или ложны.

^ Сложные высказывания. Логические операции

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

^ Помидор может быть красным и помидор может быть круглым.

Это высказывание состоит из двух простых: «Помидор может быть красным», «Помидор может быть круглым» соединённых логической связкой «И». Объединение двух и более простых высказываний логической связкой «И» называется логической операцией конъюнкции. Результатом конъюнкции является сложное высказывание, истинность которого зависит от истинности входящих в него простых высказываний и определяется следующим правилом: Конъюнкция является истинной тогда и только тогда, когда истинны все входящие в неё высказывания.

В математической логике есть общепринятое обозначение конъюнкции – . Если в конъюнкции участвуют два простых высказывания A и B, то это записывается так A  B.

Правило истинности для конъюнкции можно представить в виде следующей таблицы:

A

B

A and B

1

1

1

1

0

0

0

1

0

0

0

0

Истинность в этой таблице записывается единицей, а ложность нулем. Если A имеет значение 0 и B имеет значение 1, то конъюнкция будет такая: 0 and 1 = 0, то есть ложь.

Конечно, конъюнкция не единственная логическая операция позволяющая строить из простых высказываний сложные. Дадим определение ещё нескольких:

Дизъюнкция. Сложное высказывание являющееся дизъюнкцией двух простых истинно, если истинно хотя бы одно простое высказывание, входящее в дизъюнкцию. Обозначается дизъюнкция следующим образом:

A  B. Её таблица истинности:

A

B

A  B

1

1

1

1

0

1

0

1

1

0

0

0

Отрицание. Отрицание простого высказывания истинно, если простое высказывание ложно и ложно, если простое высказывание истинно. Обозначается отрицание так: A. Таблица истинности приведена ниже.

A

A

1

0

0

1

Эквиваленция. Сложное высказывание, построенное с помощью операции эквиваленции истинно в том случае, когда оба входящие в него высказывания одновременно истинны или одновременно ложны. Обозначается эквиваленция так: A  B. Таблица истинности приведена ниже.

A

B

A  B

1

1

1

1

0

0

0

1

0

0

0

1

Импликация. Импликация более сложная операция нежели приведенные выше. Импликация записывается так: A  B. Высказывание, записанное слева от стрелки, называется посылкой. Высказывание, записанное справа от стрелки, называется заключением. Истинность импликации определяется так: Если из истины следует истина, то импликация также истинна. Изо лжи следует все что угодно, то есть при ложной посылке независимо от следствия импликация истинна.

A

B

A  B

1

1

1

1

0

0

0

1

1

0

0

1

С помощью логических операций можно строить логические выражения любой степени сложности, истинность которых также можно определять с помощью таблицы истинности. Возьмём в качестве примера следующее выражение: (A  B)  (A  B) и построим для него таблицу истинности:

A

B

A  B

A  B

(A  B)  (A  B)

1

1

1

1

1

1

0

0

1

1

0

1

0

1

1

0

0

0

0

1

Из таблицы истинности данного выражения видно, что оно принимает истинное значение при любых значениях простых высказываний A и B. Такие выражения называются тождественно истинными. Выражения, принимающие всегда значение ложь, называются тождественно ложными.

Проверка истинности с помощью таблиц истинности не всегда проста. Логические выражения могут включать в себя много операций, количество элементарных высказываний, обозначаемых буквами, также может быть велико, а при достаточно большом количестве элементарных высказываний, таблица истинности может быть настолько велика, что построить её окажется просто невозможным.

Из таблиц приведённых выше видно, что, для их построения необходимо перебрать все возможные комбинации истинности и ложности элементарных высказываний. Для двух высказываний возможны четыре комбинации. Для трех, количество комбинаций равно 8. Для N высказываний количество комбинаций равно числу 2N. То есть, например для N=10 2N= 210 = 1024. Это уже слишком много.

В таких ситуациях уже нужны специальные приёмы для выяснения истинности и ложности выражения. Эти приёмы заключаются в упрощении исходного выражения, приведения его к стандартному, более простому виду. Под более простым видом, обычно понимается более короткое выражение, однако сократить логическое выражение может не получиться. Однако всегда можно уменьшить количество логических операций и всегда можно упростить форму логического выражения.

Существуют две стандартные формы, к которым можно привести любое логическое выражение.

^ Дизъюнктивная нормальная форма. Это логическое выражение представляющее собой дизъюнкцию элементарных конъюнкций, в которые входят элементарные высказывания или их отрицания.

Пример

(ABC)(ABC)(ABC)

^ Конъюнктивная нормальная форма. Это логическое выражение представляющее собой конъюнкцию элементарных дизъюнкций, в которые входят элементарные высказывания или их отрицания.

Пример

^ (ABC) (ABC) (ABC)

Истинность выражения представленного в нормальной форме проверяется значительно проще. Дизъюнктивная нормальная форма истинна если истинна хотя бы одна элементарная конъюнкция. Конъюнктивная нормальная форма ложна если ложна хотя бы одна элементарная дизъюнкция. Элементарная дизъюнкция истинна, если истинно хотя бы одно элементарное высказывание в неё входящее. Элементарная конъюнкция ложна, если ложно хотя бы одно элементарное высказывание в неё входящее (Отрицание высказывания элементарным не является).

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

Правила для конъюнкции и дизъюнкции
  1. a  a  a; a  a  a
  2. (a  b)  c  (a  c)  (b  c); (a  b)  c  (a  c)  (b  c);

Правила для отрицания
  1.   u  u
  2.  (u  b)   (u   b);  (u  b)   (u  b)

Правила сокращения
  1. u  (b   b)  u; u  (b   b  c)  u
  2. u  (b   b)  u; u  (b   b  c)  u

Правила устранения и введения импликации и эквиваленции
  1. (u  b)  ( u  b)
  2. (u  b)  (u  b)  ( u   b)

Пример приведения к нормальной форме

Рассмотрим следующее сложное логическое выражение:

(a  (b  c))  ( b  a)

Приведём это выражение к дизъюнктивной нормальной форме. В качестве первого шага избавимся от эквиваленций и импликаций.

(a  (b  c))  ( b  a)  ( b   a)

Упростим полученное выражение

(a  (b  c))  ( b  a)  (b   a)

Избавимся от импликации и уберём лишние скобки

 a  (b  c)  ( b  a)  (b   a).