Форум программистов, компьютерный форум CyberForum.ru

Неориентированные графы - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
08.05.2011, 14:51     Неориентированные графы #1
Никак не могу понял графы, а сдать их надо срочно...
Помогите пожалуйста, задание такое:
Задана система двусторонних дорог. Найти замкнутый путь длиной не более n, проходящий через каждую дорогу ровно один раз.
Буду просто нереально благодарен за помощь))
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.05.2011, 14:51     Неориентированные графы
Посмотрите здесь:

C++ Графы
C++ Графы
C++ [C++] графы
C++ Графы
Графы C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ValeryLaptev
Эксперт C++
1005 / 784 / 46
Регистрация: 30.04.2011
Сообщений: 1,595
08.05.2011, 17:05     Неориентированные графы #2
Цитата Сообщение от fantomart Посмотреть сообщение
Никак не могу понял графы, а сдать их надо срочно...
Помогите пожалуйста, задание такое:
Задана система двусторонних дорог. Найти замкнутый путь длиной не более n, проходящий через каждую дорогу ровно один раз.
Буду просто нереально благодарен за помощь))
Это задача на гамильтонов цикл. Алгоритмы в инете самые разные имеются.
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
09.05.2011, 14:22  [ТС]     Неориентированные графы #3
я не могу с ними разобраться, поэтому и прошу помощи
olleg90
 Аватар для olleg90
34 / 34 / 6
Регистрация: 06.01.2011
Сообщений: 90
09.05.2011, 19:23     Неориентированные графы #4
fantomart, Стас ты что ли?
@Manya@
0 / 0 / 0
Регистрация: 15.11.2009
Сообщений: 20
09.05.2011, 21:58     Неориентированные графы #5
посмотрите алгоритм Дейкстры, если у вас задана таблица стоимостей путей
Veyron
 Аватар для Veyron
104 / 104 / 4
Регистрация: 02.06.2009
Сообщений: 579
09.05.2011, 22:05     Неориентированные графы #6
Цитата Сообщение от ValeryLaptev Посмотреть сообщение
Это задача на гамильтонов цикл.
Вообще-то на эйлеров цикл.


Цитата Сообщение от @Manya@ Посмотреть сообщение
посмотрите алгоритм Дейкстры
Оно тут никаким макаром не прикрутится.

Задача решается так:
Сначала проверим, есть ли в графе эйлеров цикл. В графе есть эйлеров цикл, если все вершины имеют четную степень (то есть из них выходит (и входит, т.к. граф неориентированный) четное число ребер). Если так, то начинаем искать.
Ищется поиском в глубину, при этом помечаются при посещении не вершины, а ребра(удаляются то бишь). Как посещаем все вершины из текущей - ее в стек. Как закончится обход - в стеке эйлеров цикл, то есть ответ.
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
10.05.2011, 03:48  [ТС]     Неориентированные графы #7
а можешь написать код пожалуйста?)
ZloyVolkey
 Аватар для ZloyVolkey
27 / 27 / 6
Регистрация: 01.05.2011
Сообщений: 85
10.05.2011, 09:10     Неориентированные графы #8
Динман, С++ Освой на примерах. Там очень хорошо с примерами расписаны графы. В электронном варианте найти эту книгу не составит труда.
Veyron
 Аватар для Veyron
104 / 104 / 4
Регистрация: 02.06.2009
Сообщений: 579
12.05.2011, 16:00     Неориентированные графы #9
E-Maxx - вычисление цикла и пути Эйлера
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.05.2011, 15:20     Неориентированные графы
Еще ссылки по теме:

Графы C++
C++ Графы
графы C++

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

Или воспользуйтесь поиском по форуму:
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
29.05.2011, 15:20  [ТС]     Неориентированные графы #10
C++
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include<iostream>
#include <conio.h>
#include <fstream>
using namespace std;
//int i,j,k,N,M,one;
int **Graf;
int main()
{   int N,M,Start,pos=0,p,i,j,k, n1, n2=0, LIFO[100];
int C[2][100];
    ifstream input("input.txt");
    input>>N>>M;
    Graf=new int *[N];
    for(i=0;i<N;i++)
        Graf[i]=new int [N];
    while(!input.eof())
{       for(i=0;i<N;i++)
         for(j=0;j<N;j++)
        input>>Graf[i][j];
}
        for(i=0;i<N;i++)
            {
                for(j=0;j<N;j++)
    {
        cout<<Graf[i][j]<<" ";}
        cout<<"\n";
    }   
        cout<<"Enter Max path:";
    cin>>n1;
 
    Start=0;
    LIFO[0]=Start;
    k=1;
    while(k!=0)
    {p=0;
    for(i=0;i<N;i++)
        if(Graf[LIFO[k-1]][i]==1)
        {
            p=1;
            break;
        }
        if(p!=0)
        {
            LIFO[k]=i;
            Graf[LIFO[k-1]][i]=2;
            Graf[i][LIFO[k-1]]=2;
            k++;
        }
        else
        {
            C[0][pos]=LIFO[k-1];
            C[1][pos]=LIFO[k-2];
            pos++;
            k--;
        }
    }
    if(n1>=pos-1){
    for(i=0;i<pos-1;i++)
        cout<<C[0][i]<<" "<< C[1][i]<<endl;}
    else cout<<"no path";
    getch();
    return 0;
}
Добавлено через 1 минуту
вот я написал, но мне сейчас он выводит замкнутый путь как я понимаю через все веришины...
а надо сделать так, чтоб он выводил замкнутый путь длиной, не более n. как это реализовать?
Yandex
Объявления
29.05.2011, 15:20     Неориентированные графы
Ответ Создать тему
Опции темы

Текущее время: 04:02. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru