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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Не понятно http://www.cyberforum.ru/cpp-beginners/thread212541.html
Вот девчонка попросила написать программу,у меня не получилось,не поможите?
C++ перегрузка объектов Дан класс Окружность, включающий в себя радиус, диаметр, площадь и длину дуги. Указать все необходимые функции инициализации и доступа к объектам класса. Перегрузить для объектов класса операторы +, - , /, ++ ,-- ,&& ,|| , ==, != относительно радиуса и диаметра http://www.cyberforum.ru/cpp-beginners/thread212535.html
C++ Списки
Вот есть задание...всё вроде бы сделал,но работает не правильно...не правильно добавляет элементы...помогите разобраться... Записи в линейном списке содержат ключевое поле типа int. Сформировать однонаправленный список. Удалить из него элемент после элемента с заданным номером, добавить элемент после элемента с заданным номером; #include<iostream> using namespace std; struct node { ...
C++ график функции
Исследовать область определения функции и построить её график для произвольных значений параметров на заданном интервале (интервал и параметры задаются интерактивно) Кардиоида: x=acost(1+cost) y=asint(1+cost) a>0,t E[0,2П)
C++ стринговые константы http://www.cyberforum.ru/cpp-beginners/thread212524.html
Ввести стринговую константу. Превратить ее в трьохдиагональну матрицу, присвоив для этого нули соответствующим элементам. Транспонировать полученную матрицу относительно середины (средней строки). Конкатенировать две строки полученной матрицы. Вывести все промежуточные и конечные результаты.
C++ Кто знает,ответьте) Как реализованы строки с языке программирования Си? Почему строки называют нуль-терминальными? Сколько байт памяти необходимо для корректного хранения строки «Привет!» (без кавычек? Нарисуйте блок-схему и объясните принцип работы алгоритма вычисления длины строки. Как произвести склейку двух строк? Нарисуйте блок-схему и объясните принцип работы алгоритма подсчета цифр в тексте. Как... подробнее

Показать сообщение отдельно
potterok23
1 / 1 / 0
Регистрация: 09.12.2009
Сообщений: 11

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

16.12.2010, 17:22. Просмотров 324. Ответов 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
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru