Форум программистов, компьютерный форум, киберфорум
Prolog
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
2 / 2 / 2
Регистрация: 20.10.2016
Сообщений: 130

Построить список смежностей по матрице смежностей

07.12.2019, 17:07. Показов 1344. Ответов 1
Метки нет (Все метки)

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

Примеры
входные данные - список со списками элементов
[[0,1,0],[1,0,0],[0,0,1]] и переменная в которую создастся новый список.

выходные данные
[[0,2,0],[1,0,0],[0,0,3]]

Я пытался сделать как-то так:
Prolog
1
2
3
4
5
6
7
8
indexof(Index, Item, List):-
  nth1(Index, List, Item).
 
f([], _).
f([H|Tail], Z):-
    member(E,H),E =:= 1,!,
    indexof(X, E, H),
    f(Tail, Z).
Из indexof я получаю индекс единиц в переменную X, вопрос только в том, как теперь их записать в новый список Z.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.12.2019, 17:07
Ответы с готовыми решениями:

Построить список смежностей по представлению графа, заданному в виде матрицы смежностей
Программа должна строить список смежностей по представлению графа, заданному в виде матрицы смежностей.

Преобразовать список рёбер в список смежностей
помогите преобразовать список рёбер в список смежностей

Матрица инцидентности и смежностей
Представить граф в виде 1)матрицы смежности и матрицы инцидентности. Реализовать операторы: добавить вершину, вывод смежных вершин. На...

1
2 / 2 / 2
Регистрация: 20.10.2016
Сообщений: 130
08.12.2019, 12:17  [ТС]
UPD: Немного изменил программу:
Prolog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
indexof(Index, Item, List):-
  nth1(Index, List, Item).
 
replace(I, L, E, K) :-
  nth1(I, L, _, R),
  nth1(I, K, E, R).
 
f([], []).
f([H|Tail], [Z|RezTail]):-
    member(E,H),
    E =:= 1,
    indexof(X, E, H),
    replace(X, H, X, Z),
    f(Tail, RezTail).
Вход:
Prolog
1
f([[0,1,1],[1,0,1],[0,0,1]], Z).
Выход:
Prolog
1
Z = [[0, 2, 1], [1, 1, 0], [0, 0, 3]]
Как видно проблема в том, что после нахождения первой единицы программа уходит в рекурсию и пропускает дольнйшие элементы в списке. Есть ли какой-то вариант как избежать этого?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.12.2019, 12:17
Помогаю со студенческими работами здесь

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

Граф на основе матрицы смежностей
Необходимо решить задачу о поиске числа Исенбаева (то же самое что и Число Эрдёша только фамилия другая). Само условие задачи здесь....

Граф задается своей матрицей смежностей; вывести на экран матрицу инцидентности графа.
Пожалуйста помогите с задачкой: Граф задается своей матрицей смежностей; вывести на экран матрицу инцидентности графа. Может я много...

Граф задан своей матрицей смежностей, вывести на экран все связные вершины
Граф задан своей матрицей смежностей. Вывести на экран все связные вершины...очень скоро нужно...извините за срочность

Граф задается своей матрицей смежностей вывести на экране окружения каждой его вершины
Привет, ребят! Прошу Очень помочь! Граф задается своей матрицей смежностей. Вывести на экране окружения каждой его вершины. ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru