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

Графы. Количество отдельных государств на карте острова

21.11.2019, 10:54. Показов 17729. Ответов 1

Студворк — интернет-сервис помощи студентам
На острове расположены несколько государств, изолированных друг от друга. У программиста Васи есть данные обо всех дорогах острова, заданные в виде весовой матрицы соответствующего графа, узлы которого – города, а веса рёбер – расстояния между ними. Напишите программу, которая определяет, сколько государств находится на острове.

Входные данные
В первой строке вводится количество городов на карте N ( 1 ≤ N ≤ 1000 ). В следующих N строках записано по N чисел, разделённых пробелами – элементы весовой матрицы графа, который описывает схему дорог.

Выходные данные
Программа должна вывести одно число – количество отдельных государств на карте острова.

Есть такая функция, но не соображаю как её Внедрить...

Python
1
2
3
4
5
def f(start):
    vis[start] = True
    for i in mas[start]:
        if not vis[i]:
            f(i)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.11.2019, 10:54
Ответы с готовыми решениями:

На клеточной карте заданы острова (-1) и водная поверхность
На клеточной карте заданы острова (-1) и водная поверхность. Пользователь вводит координаты исходной и конечной точки маршрута (движение...

В программе сначала вводятся два числа в отдельных строках: координаты острова с кладом по оси X (West-East) и Y (South-
Знаменитый пират Джек Воробей опять в поисках сокровищ. На этот раз ему попалась в руки карта, где указан путь к сундуку, полному золота....

Острова в матрице (Единицы - это острова, а нули - море)
Имеется матрица (n*m) заполненная 1 и 0. Единицы - это острова, а нули - море. Если единицы находятся рядом по горизонтали или вертикали -...

1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 14
21.11.2019, 15:02
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
def start():
    n=int(input())
    matr=[[0 for i in range(n)] for j in range(n)]
    for i in range(n):
        ss=input().split(' ')
        row=list(map(int,ss))
        for j in range(n):
            k=row[j]
            matr[i][j]=k
            matr[j][i]=k
    chk=[0 for i in range(n)]
    num_est=0
    while(True):
        flg=0
        for i in range(n):
            if chk[i]==0:
                flg=1
                num_est=num_est+1
                chk[i]=1
                dfs(i,matr,chk)
                break
        if flg==0:
            return num_est
 
def dfs(v,matr,chk):
    #print(v+1)
    n=len(matr)
    for i in range(n):
        if chk[i]==0 and matr[i][v] != 0:
            chk[i]=1
            dfs(i,matr,chk)
 
print(start())
Исходные данные:

Code
1
2
3
4
5
6
7
8
9
10
9
0 1 1 0 0 0 0 0 0
1 0 1 1 0 0 0 0 0
1 1 0 1 0 0 0 0 0
0 1 1 0 0 0 0 0 0
0 0 0 0 0 1 1 0 0
0 0 0 0 1 0 1 0 0
0 0 0 0 1 1 0 0 0
0 0 0 0 0 0 0 0 1
0 0 0 0 0 0 0 1 0
Должно быть три государства.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.11.2019, 15:02
Помогаю со студенческими работами здесь

Есть острова и мосты между ними. Нужно обойти все острова, побывав на каждом мосту по разу
Задача "Острова и мосты" (задача Эйлера). Есть острова и мосты между ними. Нужно обойти все острова, побывав на каждом мосту по разу. ...

Отображение данных таблицы на карте РФ или отдельных регионов
Требуется визуализация данных. Как на форму в виде карты РФ (на рисунок) вывести данные по Федеральным округам? При чем в каждой...

Описать структуру типа «государство». Учесть название, часть мира, столицу, язык. Вывести количество государств описан
Описать структуру типа «государство». Учесть название, часть мира, столицу, язык. Вывести количество государств описанных в структуре,...

Найти количество отдельных букв
Помогите написать программу пожалуйста!!! 1)в заданной строке: 1.количество отдельных букв(например, буква а); 2.количество цифр; ...

Определить по карте количество островов
На карте островного государства Лимония, которая хранится в виде прямоугольной таблицы, нули обозначают море, а единицы -– сушу. Все...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru