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

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

Войти
Регистрация
Восстановить пароль
 
potterok23
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 11
#1

Пути в графе - C++

16.12.2010, 17:22. Просмотров 326. Ответов 0
Метки нет (Все метки)

напечатать все пути в неориентированном графе.Знаю, что есть много задач на графы и пути, но такой не могу найти=( Граф задать в классе.Часть программы у меня уже есть, но она находит только один путь.


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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include <iostream>
#include <fstream>
using namespace std;
class graf
{   private:
int *a;
int b[7][7];
public:
    graf()
    {this->a=new int;
 
        a=0;
    
    }
 
 
    graf(int a1)
    {   this->a=new int;
            *this->a=a1;
 
        
    }
 
    void show()
    { cout <<"a-"<<*a<<" ";
        for(int i=0;i<*a;i++)
    {
        cout <<"\nverwyna "<<i<<"    ";
      for(int j=0;j<*a;j++)
      {
          cout <<b[i][j]<<" ";
      }
    }
    }
    void put1()
    {
        ifstream fin;
        
        fin.open("graff.txt");
        for(int i=0;i<*a;i++)
        {
            //cout <<"\nVvedit dlya "<<i+1<<" ";
             for(int j=0;j<*a;j++)
                 fin >>b[i][j];
             
        }
    }
 
 
    void wlyax(int d,int c)
    {int f[10][10],g;
    bool visit[7][7];
    for(int i=0;i<10;i++)
             for(int j=0;j<10;j++)
                  f[i][j]=0;
    
        
    cout <<"po4-"<<d<<endl;
    cout <<"kin-"<<c<<endl;
 
     for(int j=0;j<*a;j++)  
         for(int i=0;i<*a;i++)
         { if (b[i][j]==d) b[i][j]=-1;
     visit[i][j]=false;}
 
     
 
        for(int k=0;k<4;k++)
        {
            for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
                  f[i][j]=-1;
            int i=d;
        
        
        
              for(int j=0;j<*a;j++)
            
        { 
              if ((b[i][j]>=0)&&(!visit[i][j]))
              {  f[i][j]=b[i][j];
            
         
         // visit[i][j]=true;
         g=i;
          
             if (b[i][j]==c) {  cout <<"kinec"<<d<<" "<<c;  }
            else {if (b[i][j]>=0) i=b[i][j]; /* b[g][j]=-1;*/ } 
    
            }
              b[0][0]=-1;
             
              }
 
    
          cout <<"\n a teper wlyax-";
         for(int i=0;i<7;i++)
         {// cout <<endl;
              for(int j=0;j<7;j++)
                {  if (f[i][j]>=0)
                cout <<f[i][j];}}
         cout <<"\nMatrix\n";
          for(int i=0;i<7;i++)
         { cout <<endl;
              for(int j=0;j<7;j++)
               
              cout <<b[i][j]<<" ";}
              
    }  
       
    }
 
    
    
    };
    void main()
    {
        graf A(7);
        A.put1();
        A.show();
        A.wlyax(0,6);
        
        system("pause");
    }
А вот и граф
1 3 -1 -1 -1 -1 -1
0 4 -1 -1 -1 -1 -1
3 6 -1 -1 -1 -1 -1
0 2 -1 -1 -1 -1 -1
1 5 6 -1 -1 -1 -1
4 6 -1 -1 -1 -1 -1
4 5 -1 -1 -1 -1 -1
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.12.2010, 17:22
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Пути в графе (C++):

Пути на графе - C++
Здравствуйте, помогите пожалуйста придумать алгоритм поиска путей на орентированом графе. Пример: 0 8 7 2 0 0 0 3 0 8 0 8 0 0 0...

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

Поиск кратчайшего пути в графе - C++
Добрый вечер! Помогите решить задание пожалуйста: написать программу, решающую задачу в соответствие с вариантом, и вывести результат...

Восстановление кратчайшего пути в графе - C++
Есть алгоритм нахождения кратчайших путей(Флойд), а как восстановить путь как узнать через какие вершины он прошел?туплю прогаю с утра)) ...

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

Поиск кратчайшего пути на графе - C++
Выдает ошибку Error 1 error C4996: 'itoa': The POSIX name for this item is deprecated. Instead, use the ISO C++ conformant name: _itoa. See...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.12.2010, 17:22
Привет! Вот еще темы с ответами:

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

Нахождение кратчайшего пути в графе, алгоритм Уоршелла - C++
Привет всем! алгоритм уоршелла, нужно найти кратчайший путь в графе. ввожу матрицу 0 1 5 1 0 2 5 2 0 работает нормально, все...

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

Найти вероятность существования пути в графе между заданными точками - C++
Запутался в рекурсии. Смысл задачи: найти вероятность существования пути в графе между заданными точками. Смысл функции gen() на данном...


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

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

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