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

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

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

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

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

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

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

Графы - C++
1) Построить граф, используя язык С++ (или Си), согласно данной схеме на рис.1. 2) По запросу пользователя должны удаляться: • все...

С++ и графы - C++
Доброго времени суток. Хотел бы попросить помощи в написании программы. Нужно создать программу которая будет проводить расчет сетевого...

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

Графы на С++ - C++
Помогите плиз! Есть задача: Посвящение в студенты.Есть n студентов.НЕ ВСЕ знают друг друга.Но у каждого есть знакомые..Действует...

Графы - C++
Суть задачи: дан ориентированный граф, у которого каждая вершина (не ребро) имеет вес. Нужно найти путь из любой точки в любую, но чтобы он...

графы - C++
помогите пожалуйста написать программу! Составить программу печати всех циклов ориентированного графа Добавлено через 2 часа 21...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ValeryLaptev
Эксперт С++
1039 / 818 / 48
Регистрация: 30.04.2011
Сообщений: 1,659
08.05.2011, 17:05     Неориентированные графы #2
Цитата Сообщение от fantomart Посмотреть сообщение
Никак не могу понял графы, а сдать их надо срочно...
Помогите пожалуйста, задание такое:
Задана система двусторонних дорог. Найти замкнутый путь длиной не более n, проходящий через каждую дорогу ровно один раз.
Буду просто нереально благодарен за помощь))
Это задача на гамильтонов цикл. Алгоритмы в инете самые разные имеются.
fantomart
2 / 2 / 0
Регистрация: 28.11.2010
Сообщений: 41
09.05.2011, 14:22  [ТС]     Неориентированные графы #3
я не могу с ними разобраться, поэтому и прошу помощи
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
106 / 106 / 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
27 / 27 / 6
Регистрация: 01.05.2011
Сообщений: 85
10.05.2011, 09:10     Неориентированные графы #8
Динман, С++ Освой на примерах. Там очень хорошо с примерами расписаны графы. В электронном варианте найти эту книгу не составит труда.
Veyron
106 / 106 / 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++ класс, описывающий граф/орграф. Класс должен поддерживать следующую функциональность: • определение числа вершин; ...

Графы (с++) - C++
Помогите с задачей: граф задается своей матрицей смежностей; вывести на экран матрицу инцидентности графа. Добавлено через 1 час 34...

Графы - C++
добрый день! помогите решить задачу: Соединением графов G1 и G2 называется граф G=(V,E), для которого V=V1объединениеV2,...

*Графы* - 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     Неориентированные графы
Ответ Создать тему
Опции темы

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