Тема Графы и турниры

Эйлеровы графы

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела графы и турниры
Решаем задачи

Ошибка.
Попробуйте повторить позже

Задача 1#94489

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

Подсказки к задаче

Подсказка 1

В ориентированном графе сильная связность и равенство входящих и исходящих ребер что-то еще означает. Что именно?

Подсказка 2

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

Показать доказательство

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

Выделим в нашем эйлеров цикле простой цикл и удалим его, тогда сильная связность не нарушится, ведь степень каждой вершины в графе была хотя бы 2.

Ошибка.
Попробуйте повторить позже

Задача 2#34036

В углах шахматной доски 3× 3  стоят четыре коня: два белых (в соседних углах) и два чёрных. Можно ли за несколько ходов поставить коней так, чтобы во всех соседних углах стояли кони различного цвета?

Показать ответ и решение

Нарисуем граф ходов коня, получится, что кони стоят по циклу и не могут друг “сквозь” друга пройти, следовательно, свой порядок они не изменят.

Ответ: Нет, нельзя

Ошибка.
Попробуйте повторить позже

Задача 3#34037

Можно ли нарисовать 1) открытый конверт, 2) закрытый конверт не отрывая руки.

Показать ответ и решение

С пунктом 1) все просто: это легко сделать, если начать из нижней вершины. А вот в пункте 2) ничего не получается. Действительно ли это невозможно, или мы просто плохо стараемся? Оказывается, невозможно, и доказать это можно так.

Рассмотрим левую нижнюю вершину. Ее степень равна трем, значит, если в какой-то момент мы в нее “вошли”, то “выйдя”, оставим лишь одно ребро. Следовательно, в этой вершине нужно либо начать путь, либо закончить. Однако то же самое работает и для остальных трех вершин, а началом и концом могут быть только две вершины. Противоречие.

Ответ: 1) Можно, 2) нельзя

Ошибка.
Попробуйте повторить позже

Задача 4#34038

На день рождения к Андрею пришли Вася, Глеб, Даша, Митя, Петя, Соня и Тимур. Покажите, как восьмерых ребят можно рассадить за круглый стол, чтобы у любых двух, сидящих рядом, в именах встречались одинаковые буквы.

Показать ответ и решение

Нарисуем граф: вершины — имена, а ребро между вершинами означает, что в соответствующих именах есть одинаковая буква.

Тогда от Глеба отходит всего два ребра: к Андрею и Пете. Тогда Глеб точно сидит рядом с Андреем и Петей.

Аналогично от Даши отходи два ребра: к Андрею и Васе. Тогда Даша сидит именно рядом с Андреем и Васей. Уже получили рассадку пяти ребят:

Петя — Глеб — Андрей — Даша — Вася

От Тимура тоже отходит ровно два ребра: к Мите и Пете. Получаем цепочку:

Митя — Тимур — Петя — Глеб — Андрей — Даша — Вася

На оставшееся место посадим Соню, она как раз соединена с Митей и Васей.

Ответ: Митя - Тимур - Петя - Глеб - Андрей - Даша - Вася - Соня

Ошибка.
Попробуйте повторить позже

Задача 5#34039

Можно ли нарисовать треугольник и его 1) одну, 2) две медианы, не отрывая руки?

Показать ответ и решение

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

2) Рассмотрим картинку как граф: вершины — точки пересечения отрезков, ребра — отрезки между точками (ближайшими на отрезке). И, следовательно, нам нужно найти эйлеров путь в таком графе, чтобы нарисовать картинку, не отрывая руки. Но в нашем графе ровно 4 вершины нечетной степени (а именно третьей), значит, в таком графе нет эйлерова пути (по нашей лемме).

Ответ: 1) Можно, 2) нельзя

Ошибка.
Попробуйте повторить позже

Задача 6#34040

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

Показать ответ и решение

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

Ответ: Да, может

Ошибка.
Попробуйте повторить позже

Задача 7#34041

Дан кусок проволоки длиной 120 см. Можно ли, не ломая проволоки, изготовить каркас куба с ребром 10 см?

Показать ответ и решение

Предположим, что мы смогли сделать такой кубик. В нем 12 ребер по 10 см, следовательно, по каждому ребру кубика проволока проходит ровно 1 раз. Значит, мы можем провести взглядом по проволоке от ее начала и до конца, пройдя по всем ребрам куба. Получили эйлеров путь (даже цикл). Однако степень каждой вершины куба в графе, где вершины — вершины куба, а ребра — ребра куба, равна трем, то есть в нашем графе больше двух вершин имеют нечетную степень. Получили противоречие нашей лемме об эйлеровом пути.

Ответ: Нет

Ошибка.
Попробуйте повторить позже

Задача 8#34042

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

Показать ответ и решение

Построим граф ходов коня по клеткам, то есть такой граф, где вершины — клетки, а ребром соединяются клетки, если из первой во вторую можно попасть за один ход коня. Теперь нужно пройти по всем вершинам (не ребрам!) этого графа.

Ответ: Можно

Ошибка.
Попробуйте повторить позже

Задача 9#34043

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

Показать ответ и решение

Сначала попробуем нарисовать так две пересекающихся окружности. Сделать это несложно.

Теперь будем как бы добавлять по одной окружности к уже нарисованным. На самом деле предположим, что все окружности, кроме одной, мы уже умеем обводить. Тогда будем обводить все эти окружности, кроме выбранной, и, дойдя до точки пересечения нашей окружности с какой-то другой, которую мы сейчас обводим, вставим обвод нашей окружности в это место. Потом продолжим тот же путь, как ничего и не было.

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

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 10#34044

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

Показать ответ и решение

Назовем нечетные вершины А и Б. Выберем начальную нечетную вершину А и будем идти по ребрам (каждый раз по новым) до тех пор, пока не встретим вершину, в которой мы уже были (то есть замкнемся) или не придем в В (так как из всех остальных мы обязательно можем выйти, как только зашли в них).

Если мы пришли снова в выбранную начальную вершину А, то можем снова из нее выйти, так как ее степень нечетна (будем считать, что мы снова начали путь, выкинув прошедшие ребра). Продолжим путь.

Если мы снова попали не в начальную вершину (и не в Б), то мы снова можем из нее выйти, так как сейчас мы зашли в нее на один раз больше, чем вышли (а ее степень четна, то есть можем еще раз выйти по новому ребру). Продолжим путь.

Если же мы попали в Б и еще остались какие-то ребра, то хотя бы одно оставшееся ребро связано с нашим пройденным путем (так как граф связный). Тогда у вершины, которая соединена этим ребром с вершиной из нашего пути (назовем вершину из пути С), степень нечетна (если вершина не А и не Б) или четна (если это вершина А или Б), то есть из нее можно выйти. Идем далее по этим ребрам из С (по новым каждый раз и не из пути), как и раньше делали с путем. Тогда мы всегда можем идти дальше, пока не вернемся обратно в С. Теперь просто вставим этот участок в наш путь.

Таким образом мы сформируем путь по всем ребрам (так как их конечное число).

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 11#34045

При каких n  правильный n  -угольник со всеми его диагоналями можно нарисовать не отрывая карандаша?

Показать ответ и решение

Представим картинку в виде естественного графа, где вершины — вершины многоугольника, ребра — стороны многоугольника и диагонали. Тогда степень каждой вершины многоугольника равна n− 1  .

Если n  четное, то у нас есть много (больше двух при n> 2  ) вершин с нечетными степенями, следовательно, эйлерова пути точно нет.

Если n  нечетное, то все степени вершин четные. Тогда аналогично 7 задаче можем найти эйлеров путь.

Ответ: При всех нечетных n и n = 2

Ошибка.
Попробуйте повторить позже

Задача 12#35501

Город в плане выглядит как квадрат 3×3  , каждая сторона квартала- квадратика — участок улицы длиной 100 м (включая внешний контур квадрата). Какой наименьший путь придется проделать паровому катку, чтобы заасфальтировать все улицы?

Показать ответ и решение

Рассмотрим граф с вершинами в узлах сетки и ребрами — отрезочками между узлами. Заметим, что в графе есть 8 вершин нечетной степени (по 2 на каждой стороне). Заметим, что как минимум в 6 из них наш маршрут не начинается и не заканчивается. А значит, мы входили в эти вершины столько же раз, сколько и выходили из них. То есть для каждой такой вершины одно из ее ребер было пройдено дважды. Отметим для каждой из наших вершин такое ребро. Заметим, что одно и то же ребро может быть отмечено не более 2 раз (по одному раз для каждого конца). Поэтому мы прошли дважды хотя бы по 3 ребрам. Поэтому длина нашего пути не меньше, чем (12⋅2+ 3)⋅100 =2700  метров.

Теперь приведем пример. Начнем из второго сверху перекрестка на самой правой улице. Сначала обойдем всю границу. Мы вернулись в начальный перекресток. Теперь идем так: влево, вверх, влево, вниз, влево, вниз, вправо, вниз, вправо, вверх, вверх, влево, вниз, вправо, вправо. В итоге как раз получится 2700 метров.

Ответ: 2700

Ошибка.
Попробуйте повторить позже

Задача 13#35502

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

Показать ответ и решение

Пусть данный граф — G  . Начнем идти из произвольной вершины v
1  . Пусть на очередном шаге мы пришли в вершину v  . Если мы начинали обход с v  , то мы сможем куда-то выйти из v  по ранее не задействованному ребру (так как для каждой вершины число входов равно числу выходов). То есть рано или поздно мы вернемся в v1  . Получили некоторый цикл P1  . Если P1  содержит все ребра графа    G  , то в этот цикл входят и все вершины, а следовательно из любой вершины можно перейти в любую другую. В противном случае, удалив из G  ребра P1  , получим граф G2  . Так как у всех вершин в G  и P1  одинаковое количество входящих и выходящих ребер, то и G2  будет обладать этим свойством. В силу связности G  графы P1  и G2  должны иметь хотя бы одну общую вершину v2  . Теперь, начиная из v2  , построим в G  цикл P2  подобно тому, как построили P1  . Объединим циклы P1  и P2  следующим образом: пройдем часть P1  от вершины v1  до вершины v2  , затем пройдем цикл P2  , затем — оставшуюся часть P1  от v2  до v1  .

Если объединенный цикл опять не содержит некоторое ребро графа G  , то, проделав аналогичные построения, получим еще больший цикл. Так будем делать пок не получим цикл, содержащий все ребра.

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 14#35503

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

Показать ответ и решение

Пусть данный граф — G  . Начнем чередующуюся цепь P
 1  из произвольной вершины v
 1  , и будем продлевать ее, выбирая каждый раз новое ребро. Так как степени вершин четные, то, попав в некоторую вершину, мы всегда будем иметь в распоряжении еще не пройденное ребро другого цвета. Таким образом, построение цепи P1  обязательно закончится в вершине v1  , и P1  будет циклом. Если P1  содержит все ребра графа G  , то построен нужный эйлеров цикл. В противном случае, удалив из G  ребра P1  , получим граф G2  . Так как у всех вершин в G  и P1  одинаковое количество выходящих черных и красных, то и G2  будет обладать этим свойством. В силу связности G  графы P1  и G2  должны иметь хотя бы одну общую вершину v2  . Теперь, начиная из v2  , построим в G  цикл P2  подобно тому, как построили P1  . Объединим циклы P1  и P2  следующим образом: пройдем часть P1  от вершины v1  до вершины v2  , затем пройдем цикл P2  , затем — оставшуюся часть P1  от v2  до v1  .

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

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 15#35504

Турист приехал в город и прогулялся по городу. Докажите, что он может вернуться на вокзал, проходя только по тем улицам, которые он проходил нечётное число раз.

Показать ответ и решение

Построим граф, вершинами которого являются перекрестки между улицами, а ребрами — сами улицы. Также условимся, что в нашем графе разрешены кратные ребра (то есть, если турист прошел дважды по одной улице, то этой улице будут соответствовать 2 ребра). Пусть мы начали прогулку в вершине X  , а закончили — в вершине Y  . Оставим в графе только ребра, соответствующие улицам, пройденным нечетное количество раз.

Заметим, что изначально в графе степень всех вершин, кроме X  и Y  была четная (поскольку мы пришли в эти вершины столько же раз, сколько и вышли из них). После выкидывания ребер, которые соответствовали улицам, пройденным четное число раз, у нас степени всех вершин сохранили свою четность. При этом степени X  и Y  остались нечетными. Предположим, что из X  нельзя добраться до   Y  по оставшимся ребрам. Тогда эти вершины лежат в разных компонентах связности. Но тогда в компоненте X  есть ровно 1 вершина нечетной степени, что невозможно.

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 16#35505

Из каждого города в другие города страны ведут ровно 3 дороги. Докажите, что две компании могут так приватизировать эти дороги, что из каждого города будут выходить 2 дороги одной и 1 дорога другой компании.

Показать ответ и решение

Построим граф: вершины — города, ребра — дороги. Городов в стране четное количество, по лемме о рукопожатиях, пронумеруем города от 1  до 2n  . Проведём дополнительных n  ребер: между 1  и 2  , 3  и 4  , …, 2n − 1  и 2n  (ребра могли получится кратными). Полученный граф является эйлеровым. Давайте начнем путь по циклу из вершины 1  по добавленному ребру, и поочередно отдавать дороги компаниям. В конце процесса у всех кроме, возможно, вершины 1  ровно по 2 дороги каждой компании. У 1  есть настоящие ребра обеих компаний, так как мы в какой-то момент зашли и вышли из нее. Затем уберём добавленные ребра, для любой вершины будет выполнятся условие, так как мы убрали всего одного ребро, исходящее из нее.

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 17#35506

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

Показать ответ и решение

Рассмотрим граф, вершинами которого являются пары цифр (упорядоченные). Количество таких пар 10⋅10= 100  (каждое из 2 чисел можно выбрать 10 способами). Будем проводить стрелочку из вершины A  в вершину B  , если второе число A  равно первому числу   B  . Заметим, что из каждой вершины выходит 10 ребер и входит 10 ребер. Если мы сотрем ориентацию на ребрах, то легко видеть, что полученный граф будет связным. Тогда также как и во второй задаче найдем ориентированный цикл, содержащий все ребра. Заметим, что каждой последовательности из 3 чисел соответствует ровно 1 ребро (между первыми двумя числами и последними двумя числами). Выпишем сначала произвольную пару чисел, а затем будем дописывать следующую согласно нашему циклу (то есть, если мы выписали числа из вершины A  , а следующей в нашем цикле является вершина B  , то допишем на доску последнюю цифру B  и так далее). Поскольку мы прошли по всем ребрам ровно 1 раз, у нас встретятся все комбинации из 3 чисел, причем ровно по 1 разу, что и требовалось.

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 18#35507

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

Показать ответ и решение

Назовём город “захолустным”, если из него идёт не более двух дорог. Сотрём с карты страны любой захолустный город, если таковой имеется, вместе с выходящими из него дорогами. Подчистим таким же образом новую карту и будем продолжать стирание захолустных городов, пока они не исчезнут. Число дорог, которые мы при этом можем стереть, не превосходит 2⋅1988 <4000  ; поэтому хотя бы один город останется.

Выберем любой из оставшихся городов. Из него, как и из других оставшихся городов, выходят по меньшей мере три дороги. Пойдём по одной из них и каждый раз, приходя в новый город, будем двигаться дальше по одной из дорог, отличных от дороги, по которой мы пришли. Если какие-нибудь два маршрута, состоящие не более чем из 10 дорог, закончатся в одном городе, то мы получим искомый кольцевой маршрут не более чем из 20 дорог. В противном случае число всех таких маршрутов не меньше чем         2       9    10
3(1+2 +2 + ...+ 2)= 3(2 − 1)=3069  , а число городов, то есть возможных концов этих маршрутов — не больше 1988. Противоречие.

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 19#35509

В стране Центумии некоторые пары городов соединены дорогами, причем из каждого города выходит ровно 100 дорог. Пучком называется набор из 10 дорог, выходящих из одного города. Докажите, что все дороги можно разбить на несколько пучков.

Показать ответ и решение

Рассмотрим граф G  , в котором вершины — это города, а рёбра — дороги. Степени всех вершин этого графа равны 100. Начнем ходить из произвольной вершины графа. Будем ходить по ранее не пройденным ребрам, пока можем. Если мы в какой-то момент не сможем выйти из вершины, то мы прошли все 100 ребер, выходящих из нее. Предположим, что эта вершина, отличная от стартовой. Тогда число входов в вершину на 1 больше числа выходов, следовательно мы посетили нечетное число ребер, выходящих из вершины (каждый вход и выход добавляет одно ребро). То есть мы зациклились. Выкинем все ребра этого цикла. У каждой вершины степень по-прежнему четна. Опять найдем цикл, выкинем все его ребра и так далее.

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

Ответ:

Ошибка.
Попробуйте повторить позже

Задача 20#37113

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

Показать доказательство

Пусть на ремонт закрыли дорогу из города A  в город B  .

По условию от любого города до другого существовал маршрут не более, чем из двух дорог. Если этот маршрут не содержал дорогу A → B  , то и после ремонта выполнено условие, что добраться данным маршрутом можно не более, чем по трём (даже двум) дорогам. Осталось рассмотреть маршруты вида 1)A → B → X,2)X → A → B,3)A → B  , где X  - произвольный город, отличный от A  и B  .

1)  Для первого случая используем, что из A  осталась дорога хотя бы в один город Y  , иначе из A  было бы невозможно никуда добраться. В случае Y = X  получен маршрут из одной дороги A → X  , иначе же всё равно существует маршрут из Y  в B  не более, чем из двух дорог, не проходящий через дорогу AB  , за счёт условия на исходную дорожную систему до ремонта. Ведь в случае прохождения маршрута от Y  к B  через AB  пришлось бы добраться до города A  за один переезд, но из Y  в A  пути нет — дорога направлена в другую сторону.

2,3)  Для второго и третьего случаев используем, что в B  осталась дорога хотя бы из одного города Z ⁄= A  , иначе в B  было бы невозможно попасть. В случае X = Z  получен маршрут из одной дороги Z → B  , иначе же всё равно существует маршрут из исходного города (X  или A  ) в Z  не более, чем из двух дорог, не проходящий через дорогу AB  , за счёт условия на исходную дорожную систему до ремонта. Ведь в случае прохождения маршрута от A  (или X  ) к Z  через AB  пришлось бы добираться из города B  в город Z  за один(не более, чем один) переезд, но такое сделать невозможно — дорога направлена в другую сторону.

В итоге путь имеет длину не больше трёх.

Рулетка
Вы можете получить скидку в рулетке!