Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 06.08.2020
Сообщений: 9

В городе N в ближайшее время состоится этап чемпионата мира по автогонкам среди автомобилей класса Формула-0

06.08.2020, 11:45. Показов 2133. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите с решением задачи.

В городе N в ближайшее время состоится этап чемпионата мира по автогонкам среди автомобилей класса Формула-0. Поскольку специальный автодром для этих соревнований организаторы построить не успели, было решено организовать трассу на улицах города.

В городе N есть n перекрестков, некоторые пары которых соединены дорогами, движение по которым возможно в обоих направлениях. При этом любые два перекрестка соединены не более чем одной дорогой, и есть возможность доехать по дорогам от любого перекрестка до любого другого.

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

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

Напишите программу, которая по заданному списку дорог города определит, возможна ли организация в городе требуемой круговой трассы.

Входные данные
Первая строка входного файла INPUT.TXT содержит два целых числа: n (1 ≤ n ≤ 103) – количество перекрестков в городе N и m (0 ≤ m ≤ 105) – количество дорог в составленном списке.

Последующие m строк описывают дороги. Каждая дорога описывается двумя числами: u и v (1 ≤ u, v ≤ n, u ≠ v) номерами перекрестков, которые она соединяет. Так как дороги двухсторонние, то пара чисел (u, v) и пара чисел (v, u) описывают одну и ту же дорогу.

Выходные данные
В выходной файл OUTPUT.TXT выведите слово YES, если в городе возможно организовать круговую трассу для соревнований, и слово NO в противном случае.

Примеры:
Ввод Вывод
3 4 YES
1 2
2 3
3 1
3 2

2 3 NO
1 2
2 1
2 1
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.08.2020, 11:45
Ответы с готовыми решениями:

Ваши впечатления от чемпионата мира 2014
Ну делитесь, у кого какие впечатления после вчерашнего финала. За кого болели? Оправдала ли игра ожидания?

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

Программа обработки итоговой таблицы Чемпионата Мира по Футболу
Разработать программу обработки итоговой таблицы Чемпионата Мира по Футболу. Исходные данные вводятся из файла. Обработка включает в...

2
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
06.08.2020, 11:56
Лучший ответ Сообщение было отмечено GTim как решение

Решение

На математическим языке - определить, является ли граф циклическим.
1
0 / 0 / 0
Регистрация: 06.08.2020
Сообщений: 9
08.08.2020, 09:39  [ТС]
Решение есть, только по времени не проходит
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
n, m = map(int, input().split())
s = [[0 for i in range(n)] for i in range(n)]
for i in range(m):
    u, v = map(int, input().split())
    s[u - 1][v - 1] = 1
    s[v - 1][u - 1] = 1
f = 1
ans = 'YES'
while f != 0:
    for i in range(n):
        f = 0
        if s[i].count(1) == 1:
            j = s[i].index(1)
            s[i][j] = 0
            s[j][i] = 0
            f = 1
            break
        if s == [[0 for i in range(n)] for i in range(n)]:
            f = 0
            ans = 'NO'
            break
print(ans)
Добавлено через 15 минут
Можно оптимизировать, изначально создав массив а (
Python
1
a = [[0 for i in range(n)] for i in range(n)]
), а в 18-ой строке сравнивать массив s с массивом а, но этого не достаточно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.08.2020, 09:39
Помогаю со студенческими работами здесь

Россия впервые стала хозяйкой чемпионата мира по футболу
Чемпионат мира по футболу в 2018 году пройдет в России, а в 2022 году – в Катаре. Об этом в Женеве объявил вечером 2 декабря президент ФИФА...

Россия готовит заявку на проведение чемпионата мира по футболу в 2018 году
Россия готовит заявку на проведение первенства мира по футболу в 2018 году. Об этом сегодня докладывал на встрече с президентом РФ Дмитрием...

Определить, кто выиграл этап гонки "Формула 1"
Привет, помогите пожалуйста. Нам дали задание в прологе, который мы в глаза не видели, но это как бы не их проблемы. Побывав на множестве...

Логическая задача: определить, кто выиграл этап гонки "Формула 1"
болельщики автогонок "Формула-1", спорили о результатах предстоящего этапа гонок. — Вот увидишь, Шумахер не придет первым, — сказал...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru