![]() |
Модераторы: Daevaorn |
![]() ![]() ![]() |
|
Gether |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 5 Регистрация: 15.12.2004 Репутация: нет Всего: нет |
Люди!Помогите пожалуйста!Срочно нужна программа!
Программа на C/C++: Представление графов Вершины графов заданы номерами или названиями пунктов На дугах определены числа ("расстояние" или "стоимость") Граф G задается списком исходящих из а дуг, например, (помеченных взвешенных дуг) вида G=a:(b,2.0),(c,2),(f,3.1); или списком троек вида G=(a,b,1.2),(a,c,2),(a,f,3.1); где a - название исходной вершины. Задание: 5. Вершины графа разбиты на два подмножества - красные (A) и синие (B). Найти кратчайший путь из красной вершины а до ближайшей синей. ![]() |
|||
|
||||
sergejzr |
|
|||
![]() Un salsero ![]() Профиль Группа: Админ Сообщений: 13285 Регистрация: 10.2.2004 Где: Германия г .Ганновер Репутация: 19 Всего: 360 |
Начинай писать, поможем
![]() |
|||
|
||||
Gether |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 5 Регистрация: 15.12.2004 Репутация: нет Всего: нет |
sergej.z Как лучше описывать граф на C?В виде матрицы?
|
|||
|
||||
sergejzr |
|
|||
![]() Un salsero ![]() Профиль Группа: Админ Сообщений: 13285 Регистрация: 10.2.2004 Где: Германия г .Ганновер Репутация: 19 Всего: 360 |
Я просто делал массив из узлов.
узел - структура. |
|||
|
||||
Gether |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 5 Регистрация: 15.12.2004 Репутация: нет Всего: нет |
sergej.z Есть какие-нибудь примеры?С чего начать?
|
|||
|
||||
sergejzr |
|
|||
![]() Un salsero ![]() Профиль Группа: Админ Сообщений: 13285 Регистрация: 10.2.2004 Где: Германия г .Ганновер Репутация: 19 Всего: 360 |
У тебя структура узел. В ней указатели на всех соседей(структуры дуги). Добавочно цвет, номер, название.
Дуга - содержит просто указатель на соседний узел и свой вес. Добавлено @ 21:49
Ну, если на Си++ пишешь, можешь ессно классы делать, а не структуры. Вообще по моему здесь на форуме этот вопрос часто задавался. Попробуй поиск... |
|||
|
||||
lexer |
|
|||
Новичок Профиль Группа: Участник Сообщений: 4 Регистрация: 19.2.2007 Репутация: нет Всего: нет |
для представления графов используются матрица смежности или инциденции...
в аттаче пример поиска кратчайшего пути между вершинами методом фронта волны. вводим кол-во вершин, заполняем матрицу смежности и задаем между какими вершинами нужно показать путь (консольный вариант) Это сообщение отредактировал(а) lexer - 19.2.2007, 20:19 Присоединённый файл ( Кол-во скачиваний: 35 ) ![]() |
|||
|
||||
lexer |
|
|||
Новичок Профиль Группа: Участник Сообщений: 4 Регистрация: 19.2.2007 Репутация: нет Всего: нет |
вообще сейчас у меня похожая проблема, пишу программу с графическим интерфейсом для работы с графами. Вообщем она должна будет делать следующее:
1) заполняем матрицу смежности, программа строит граф и заполняет матрицу инциденций 2) заполняем матрицу инциденций, программа строит граф и заполняет матрицу смежности 3) сами рисуем граф, нанесением точек("вершин") и соединяющих линий("ребер") с возможностью их вращения, программа заполняет матрицу смежности и инциденций. 4) планирую сохранение в файл проекта и последующая загрузка из него. Подскажите может есть готовые модули для работы с графами или литература, где можно почитать про них? Заранее спасибо! |
|||
|
||||
Earnest |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Экс. модератор Сообщений: 5962 Регистрация: 17.6.2005 Где: Рязань Репутация: 53 Всего: 183 |
Boost graph library
-------------------- ... |
|||
|
||||
Okonner |
|
|||
Новичок Профиль Группа: Участник Сообщений: 25 Регистрация: 5.11.2006 Где: Питер Репутация: нет Всего: нет |
А если сделать двухсвязный список, а потом сортировку??? Или я не понял задания?
|
|||
|
||||
lexer |
|
|||
Новичок Профиль Группа: Участник Сообщений: 4 Регистрация: 19.2.2007 Репутация: нет Всего: нет |
Вот еще проблема с алгоритмом: есть у меня граф, состоящий из N вершин(в этом конкретном примере N=4), он представлен следующим образом:
1 2 (1-ая вершина смежна второй) 1 3 (1-ая смежна третьей) 2 4 (2-ая четвертой и тд) 3 2 Не важно где они записаны, в массиве, в файле..Нужно преобразовать это в матрицу смежности и забить в StringGrid (размером NxN): -|-------| |1 1 1 0| |1 1 1 1| |1 1 1 0| |0 1 0 1| -|-------| Считываю данные циклом, сначала 1 2, затем 3 1 и тд... Заранее спасибо за помощь |
|||
|
||||
lexer |
|
|||
Новичок Профиль Группа: Участник Сообщений: 4 Регистрация: 19.2.2007 Репутация: нет Всего: нет |
со смежной матрицой разобрался ;)
|
|||
|
||||
pablo |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 320 Регистрация: 12.2.2005 Где: Вильнюс, Литва Репутация: 4 Всего: 6 |
В Boost есть всё что надо для работы с графами. Как представление, так и поиск на графах.
www.boost.org -------------------- Первый блин всегда похож на сферу, иногда бывает и куб. |
|||
|
||||
![]() ![]() ![]() |
Правила форума "С++:Общие вопросы" | |
|
Добро пожаловать!
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |