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

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

Восстановить пароль Регистрация
 
potterok23
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 11
16.12.2010, 17:22     Пути в графе #1
напечатать все пути в неориентированном графе.Знаю, что есть много задач на графы и пути, но такой не могу найти=( Граф задать в классе.Часть программы у меня уже есть, но она находит только один путь.


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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.12.2010, 17:22     Пути в графе
Посмотрите здесь:

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

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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