Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
#1

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

08.05.2011, 14:51. Просмотров 1202. Ответов 9
Метки нет (Все метки)

Никак не могу понял графы, а сдать их надо срочно...
Помогите пожалуйста, задание такое:
Задана система двусторонних дорог. Найти замкнутый путь длиной не более n, проходящий через каждую дорогу ровно один раз.
Буду просто нереально благодарен за помощь))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.05.2011, 14:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Неориентированные графы (C++):

Графы - C++
Прочитал про обход графа в глубину, посмотрел реализацию, и тут вопрос а как можно использовать этот обход в глубину?

Графы - C++
Люди скиньте пожалуйста какую нибудь программку на С++ по графам, или дайте ссылку на темку на форему...

Графы - C++
Имеется сеть автомобильных дорог. Известны расстояния всех участков дорог. Некоторые участки аварийноопасны. Требуется найти путь из пункта...

[C++] графы - C++
Алгоритм фронт фолны в графе Помогите.. Дана матрица Ag (Матрица смежности графа) И координаты начальной вершины i,j и кординаты...

Графы - C++
помогите с реализацией алгоритма Дейкстры для нахождения расстояния от узла 1 в каждый узел. матрица весов такая...

Графы - C++
Написать программу, реализующую алгоритм Беллмана-Форда.

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


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

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

Графы в С++ - C++
Как можно в программу на С++ ввести граф??моей задачей является определить оптимальное расположение остановок в городе,ну и город в виде...

Графы - C++
Помогите написать программу: Модель работы некоторой системы представлена ориентированным графом, где вершины – это состояния системы,...

Графы - C++
Задан граф матрицей смежности Заданы две вершины, начальная и конечная, требуется найти первую вершину в пути между ними

Графы - C++
Дано прямоугольное клеточное поле; как создать матрицу смежности для графа ферзей?


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.