Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Графы, кратчайший путь на С\С++ 
:(
    Опции темы
Gether
  Дата 15.12.2004, 20:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 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).
Найти кратчайший путь из красной вершины а до ближайшей синей. smile
PM MAIL   Вверх
sergejzr
Дата 15.12.2004, 20:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 19
Всего: 360



Начинай писать, поможем smile


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Gether
Дата 15.12.2004, 20:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 15.12.2004

Репутация: нет
Всего: нет



sergej.z Как лучше описывать граф на C?В виде матрицы?
PM MAIL   Вверх
sergejzr
Дата 15.12.2004, 21:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 19
Всего: 360



Я просто делал массив из узлов.
узел - структура.


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Gether
Дата 15.12.2004, 21:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 15.12.2004

Репутация: нет
Всего: нет



sergej.z Есть какие-нибудь примеры?С чего начать?
PM MAIL   Вверх
sergejzr
Дата 15.12.2004, 21:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 19
Всего: 360



У тебя структура узел. В ней указатели на всех соседей(структуры дуги). Добавочно цвет, номер, название.
Дуга - содержит просто указатель на соседний узел и свой вес.
Добавлено @ 21:49

Код

struct Duga
{
double weght;
Uzel *sosed1;
Uzel *sosed2;
};
struct Uzel
{
in num;
int color;
char name[512];
Duga sosedi*;
};

Ну, если на Си++ пишешь, можешь ессно классы делать, а не структуры.
Вообще по моему здесь на форуме этот вопрос часто задавался. Попробуй поиск...


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
lexer
Дата 19.2.2007, 19:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 19.2.2007

Репутация: нет
Всего: нет



для представления графов используются матрица смежности или инциденции...

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


Это сообщение отредактировал(а) lexer - 19.2.2007, 20:19

Присоединённый файл ( Кол-во скачиваний: 35 )
Присоединённый файл  graph.rar 65,50 Kb
PM MAIL   Вверх
lexer
Дата 19.2.2007, 20:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 19.2.2007

Репутация: нет
Всего: нет



вообще сейчас у меня похожая проблема, пишу программу с графическим интерфейсом для работы с графами. Вообщем она должна будет делать следующее:
1) заполняем матрицу смежности, программа строит граф и заполняет матрицу инциденций
2) заполняем матрицу инциденций, программа строит граф и заполняет матрицу смежности
3) сами рисуем граф, нанесением точек("вершин") и соединяющих линий("ребер") с возможностью их вращения, программа заполняет матрицу смежности и инциденций.
4) планирую сохранение в файл проекта и последующая загрузка из него.

Подскажите может есть готовые модули для работы с графами или литература, где можно почитать про них?

Заранее спасибо!
PM MAIL   Вверх
Earnest
Дата 20.2.2007, 19:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 5962
Регистрация: 17.6.2005
Где: Рязань

Репутация: 53
Всего: 183



Boost graph library


--------------------
...
PM   Вверх
Okonner
Дата 21.2.2007, 00:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 25
Регистрация: 5.11.2006
Где: Питер

Репутация: нет
Всего: нет



А если сделать двухсвязный список, а потом сортировку??? Или я не понял задания?
PM MAIL   Вверх
lexer
Дата 21.2.2007, 20:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 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 и тд...
Заранее спасибо за помощь 
PM MAIL   Вверх
lexer
Дата 22.2.2007, 01:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 19.2.2007

Репутация: нет
Всего: нет



со смежной матрицой разобрался ;) 
PM MAIL   Вверх
pablo
Дата 22.2.2007, 14:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 320
Регистрация: 12.2.2005
Где: Вильнюс, Литва

Репутация: 4
Всего: 6



В Boost есть всё что надо для работы с графами. Как представление, так и поиск на графах.

www.boost.org


--------------------
Первый блин всегда похож на сферу, иногда бывает и куб.
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0866 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.