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

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

Войти
Регистрация
Восстановить пароль
 
jambas92
58 / 57 / 3
Регистрация: 18.11.2010
Сообщений: 315
#1

Двумерная матрица путей городов - C++

09.05.2012, 18:48. Просмотров 332. Ответов 2
Метки нет (Все метки)

Здравствуйте! Есть 9 городов. Kyzylorda, Atyrau, Almaty, Astana, Kostanai, Pavlodar, Semipalatinsk, Ust-Kamenagorsk, Uralsk. http://dl.iitu.kz/file.php?file=%2F943%2FKazakhstan.gif
вот так они между собой взаимосвязанный. Я создал int матрицу 9 на 9, если между двумя городами есть путь то 1 если нет, то 0.

0 1 1 0 0 0 1 1 0
1 0 1 1 0 1 0 0 0
1 1 0 0 1 0 0 0 0
0 1 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0
0 1 0 0 0 0 0 0 0
1 0 0 0 0 0 0 0 1
1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 1 0 0

для городов:
Almaty
Astana
Atyrau
Kostanai
Kyzylorda
Pavlodar
Semipalatinsk
Uralsk
Ust-Kamenagorsk

теперь вопрос. как с помощью данной матрицы сделать так что бы он показывал возможные пути от одного города до другого. Например если
ввести: Almaty Pavlodar
выход: Almaty - Astana - Pavlodar?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.05.2012, 18:48     Двумерная матрица путей городов
Посмотрите здесь:

двумерная матрица - C++
Задача 1 Пусть есть двумерная матрица А произвольной размерности. Сформировать на ее основе вектор В элементы которого являются суммы...

Двумерная динамическая матрица - C++
в общем помогите, надо написать двумерный массив(int) динамическим и пару функций к нему: 1. удаление столбца 2. удаление строки 3....

Двумерная матрица без For - C++
подскажите пожалуйста как ввести двумерную матрицй без цикла for, c одномерным массивом все понятно for(;;) { switch(Way) { ...

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

Двумерная матрица. Найти количество похожих строк. - C++
Дана целочисленная матрица размера M x N. Различные строки матрицы назовем похожими, если попарно совпадают больше половины чисел,...

Пусть имеется двумерная квадратная матрица А произвольной розмирности - C++
Пусть имеется двумерная квадратная матрица А произвольной розмирности. найты суммы элементов лежащих главной и побочной диагоналях матрицы

Двумерная матрица. Разместить сначала положительные элементы, а за ними - все остальные - C++
Помогите пожалуйста написать программу с помощью void f(); В каждой строке матрицы В (4,5) разместить сначала положительные элементы, а...

Двумерная матрица на С++ (найти все парные элементы в двумерном массиве и сложить их) - C++
Добрый вечер! Подскажите пожалуйста каким образом можно реализовать следующую задачу. Необходимо найти все парные элементы в двумерном...

Существует N городов для каждой пары городов (і, j) можно построить путь - C++
Существует N городов для каждой пары городов (і, j) можно построить путь который соединит их, но не заходит в другие города. Стоимость...

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

Двумерная Случайная Величина - C++
#include<stdio.h> #include <iostream> using namespace std; int main(){ //Функция моделирования многомерных данных,...

Двумерная очередь (FIFO) - C++
Помогите реализовать FIFO .


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
09.05.2012, 19:50     Двумерная матрица путей городов #2
Цитата Сообщение от jambas92 Посмотреть сообщение
как с помощью данной матрицы сделать так что бы он показывал возможные пути от одного города до другого.
По ссылке не удалось пройти - требуют регистрацию.
Например можно сделать перебор с помощью рекурсии, например так:
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
#include<iostream>
using namespace std;
#define N_max ?
 
int a[N_max][N_max],n,mas_res[N_max], N_res, A, B;
bool mas_kontr[N_max];
void rec(int nn)
{
    if(nn==B)
    {
        // в этом месте путь находится в массиве mas_res[], число городов в этом пути N_res. 
        //Только эти города заданы числами. Можете делать вывод, только переводите номера городов в их название
        return;
    }
    for(int i=0; i<n; i++)
        if(!mas_kontr[i] && a[nn][i]==1)
        {
            mas_kontr[i]=true;
            mas_res[N_res++]=i;
            rec(i);
            mas_kontr[i]=false;
            N_res--;
        }
}
 
int main ()
{
 //считываете n - количество городов, считываете сами пути. Формируете матрицу a[][] как писали в 1-ом посте
    //считываете A и B - начальный город и конечный город
    mas_kontr[A]=true;
    mas_res[N_res++]=A;
    rec(A);
    return 0;
}
jambas92
58 / 57 / 3
Регистрация: 18.11.2010
Сообщений: 315
09.05.2012, 19:51  [ТС]     Двумерная матрица путей городов #3
valeriikozlov да да да! Спасибо большое! Вот я рекурсию и не мог написать!
Ответ Создать тему
Опции темы

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