192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
||||||
1 | ||||||
Задача на теорию графов19.08.2017, 10:06. Показов 12417. Ответов 10
Метки нет Все метки)
(
Светофорчики
В подземелье M тоннелей и N перекрестков, каждый тоннель соединяет какие-то два перекрестка. Мышиный король решил поставить по светофору в каждом тоннеле перед каждым перекрестком. Напишите программу, которая посчитает, сколько светофоров должно быть установлено на каждом из перекрестков. Перекрестки пронумерованы числами от 1 до N. Входные данные Во входном файле INPUT.TXT записано два числа N и M (0 < N ≤ 100, 0 ≤ M ≤ N*(N-1)/2). В следующих M строках записаны по два числа i и j (1 ≤ i,j ≤ N), которые означают, что перекрестки i и j соединены тоннелем. Можно считать, что любые два перекрестка соединены не более, чем одним тоннелем. Нет тоннелей от перекрестка i до него самого. Выходные данные В выходной файл OUTPUT.TXT вывести N чисел: k-ое число означает количество светофоров на k-ом перекрестке.
0
|
|
19.08.2017, 10:06 | |
Ответы с готовыми решениями:
10
Задача на теорию автоматов Задача на теорию чисел Задача на программирование и теорию вероятностей Транспортная задача теорией графов |
19.08.2017, 11:07 | 2 | |||||
1
|
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
|
19.08.2017, 13:08 [ТС] | 3 |
А можно взять массив двумерный размером mas[N][N] и mas[a][b] делать +1?
Добавлено через 54 минуты А почему M <= n * (n - 1) / 2, разве n / 2 не будет?
0
|
1642 / 1091 / 487
Регистрация: 17.07.2012
Сообщений: 5,345
|
|
19.08.2017, 16:14 | 4 |
Можно. Но когда вершин очень много это по памяти слишком затратно.
Представьте что в графе между каждыми двумя вершинами есть ребро. Сколько ребер? Есть ребро 1-2, 1-3, ... 1-n; 2-1, 2-3, ... 2-n В общем для каждой из n вершин n-1 ребро, но мы не учли то что 1-2 и 2-1 это одинаковое ребро, потому n * (n-1) / 2
1
|
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
|
19.08.2017, 19:30 [ТС] | 5 |
Как вообще можно представить эту задачу? Ну вот у нас есть 7 перекрестков как в примере и 10 тоннелей, дальше N строк с числами какой перекресток(вершина) с каким перекрестком(вершиной) связан. Дальше что делать? Я пробовал по своему методу написать но не получилось а смысл кода выше я не очень понял
0
|
1550 / 875 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
|
||||||
20.08.2017, 18:38 | 6 | |||||
![]() Решение
2
|
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
|
20.08.2017, 19:53 [ТС] | 7 |
0
|
1550 / 875 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
|
|
20.08.2017, 19:57 | 8 |
no swear, потому, что номер перекрестка начинается с 1, а индекс вектора с 0.
1
|
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
|
21.08.2017, 07:00 [ТС] | 9 |
А если бы задавались не по два перекрестка а по три(cin >> a >> b >> c)?
0
|
1550 / 875 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
|
|
21.08.2017, 19:08 | 10 |
no swear, тогда это был бы не граф, а хзч. Но, в этом случае вместо 2 * M в условии цикла было бы... догадайтесь.
1
|
192 / 166 / 82
Регистрация: 01.07.2016
Сообщений: 943
|
|
21.08.2017, 20:06 [ТС] | 11 |
Ну если мы вводим как в последнем коде через одну переменную (cin >> node) то явно будет 3 * M
Спасибо большое за то что помогли разобраться с этой задачей, ОЧЕНЬ вам благодарен
0
|
21.08.2017, 20:06 | |
21.08.2017, 20:06 | |
Помогаю со студенческими работами здесь
11
Теория графов. Задача Обрати меня! Теорие графов. Композиция двух неор. графов. Кто понимает теорию графов? Для вас может эта задача разминка для мозга Как можно практически применить теорию случайных графов? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |