Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
2 / 2 / 1
Регистрация: 28.11.2016
Сообщений: 85

Найти путь, соединяющий города A и B, и не проходящий через заданное множество городов

06.05.2018, 00:45. Показов 4790. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
"Задана система односторонних дорог. Найти путь, соединяющий города A и B и не проходящий через заданное множество городов".


я ее сделала,только она не правильно работает, помогите найти ошибки, возможно проблема с рандомом
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
#include "stdafx.h"
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
typedef int matr[100][100];
typedef int gor[100];
matr s;
gor Q, goroda;
int  n, m, t, i_st, i_end, A, B;
 
void matr_smezh() {
    int i, j;
    for ( i = 0; i < n; i++) {
        for ( j = 0; j < n; j++) {
            srand(time(NULL));
            s[i][j] = rand() % 2;
        }
    }
    for (i = 0; i < n; i++) {
        s[i][i] = 0;
        for (j = 0; j < n; j++) {
            s[j][i] = s[i][ j];
        }
}
};
 
 
void vuvod() {
    int i, j;
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            cout << s[i][j] << ' ';
        }
        cout << endl;
    }
}
 
    void poisk(){
        int i;
        goroda[A] = 200;
    Q[0] = A; i_st = 1; i_end = 2;
    while (i_st < i_end) {
        for (i = 0; i < n; i++) {
            if ((goroda[i] == 0) && (s[Q[i_st]][i] == 1)) {
                Q[i_end] = i; i_end++; goroda[i] = Q[i_st];
            }
            i_st++;
        }
    }
};
    void vuvod_res() {
        int i;
        if (goroda[B] == 0)
            cout << "no exit" << endl;
        Q[0] = B; i_end = 2; t = goroda[B];
        while (t != A) {
            Q[i_end] = t; i_end++; t = goroda[t];
        }
        Q[i_end] = A;
        for (i = i_end; i > 1; i--)
            cout << Q[i] << ' ';
    }
 
int main()
{ 
    cout << "enter number of points in graph" << endl;
        cin >> n;
    cout << "enter number of points (where no exit)" << endl;
    cin >> m;
 
    cout << "enter points" << endl;
    for (int i = 0; i < m; i++) {
        cin >> t; goroda[t] = -1;
    }
    matr_smezh();
    cout << "adjacency matrix" << endl;
    vuvod();
    cout << endl;
    for (int i = 0; i < n; i++)
        if (goroda[i] == -1)
            cout << i << ' ';
    cout << endl;
    cout << "enter number of point A";
    cin >> A;
    cout << "enter number of point B";
    cin >> B;
    poisk();
    cout << endl;
    vuvod_res();
    cout << endl;
    system("pause");
 
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.05.2018, 00:45
Ответы с готовыми решениями:

Найти путь, соединяющий вершины a и b и не проходящий через заданное подмножество вершин V
Уффф, к завтрашнему дню нужно сдать эти задачи, помогите пожалуйста кто чем сможет :sorry: (следующие задачи через обходы в глубину и...

Посчитать количество замкнутых маршрутов, проходящий ровно через четыре различных города
Задача E. Тетрациклофобия Имя входного файла: phobia.in Имя выходного файла: phobia.out Ограничение по времени: 2 секунды ...

Найти путь, соединяющий города А и В и не проходящий через заданное множество городов
Задана система односторонних дорог. Найти путь, соединяющий города А и В и не проходящий через заданное множество городов. Помогите...

7
2 / 2 / 1
Регистрация: 28.11.2016
Сообщений: 85
06.05.2018, 12:33  [ТС]
я ее сделала,только она не правильно работает, помогите найти ошибки, возможно проблема с рандомом

"Задана система односторонних дорог. Найти путь, соединяющий города A и B и не проходящий через заданное множество городов".

заранее извиняюсь за мой английский
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
#include "stdafx.h"
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
typedef int matr[100][100];
typedef int gor[100];
matr s;
gor Q, goroda;
int  n, m, t, i_st, i_end, A, B;
 
void matr_smezh() {
    int i, j;
    for ( i = 0; i < n; i++) {
        for ( j = 0; j < n; j++) {
            srand(time(NULL));
            s[i][j] = rand() % 2;
        }
    }
    for (i = 0; i < n; i++) {
        s[i][i] = 0;
        for (j = 0; j < n; j++) {
            s[j][i] = s[i][ j];
        }
}
};
 
 
void vuvod() {
    int i, j;
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            cout << s[i][j] << ' ';
        }
        cout << endl;
    }
}
 
    void poisk(){
        int i;
        goroda[A] = 200;
    Q[0] = A; i_st = 1; i_end = 2;
    while (i_st < i_end) {
        for (i = 0; i < n; i++) {
            if ((goroda[i] == 0) && (s[Q[i_st]][i] == 1)) {
                Q[i_end] = i; i_end++; goroda[i] = Q[i_st];
            }
            i_st++;
        }
    }
};
    void vuvod_res() {
        int i;
        if (goroda[B] == 0)
            cout << "no exit" << endl;
        Q[0] = B; i_end = 2; t = goroda[B];
        while (t != A) {
            Q[i_end] = t; i_end++; t = goroda[t];
        }
        Q[i_end] = A;
        for (i = i_end; i > 1; i--)
            cout << Q[i] << ' ';
    }
 
int main()
{ 
    cout << "enter number of points in graph" << endl;
        cin >> n;
    cout << "enter number of points (where no exit)" << endl;
    cin >> m;
 
    cout << "enter points" << endl;
    for (int i = 0; i < m; i++) {
        cin >> t; goroda[t] = -1;
    }
    matr_smezh();
    cout << "adjacency matrix" << endl;
    vuvod();
    cout << endl;
    for (int i = 0; i < n; i++)
        if (goroda[i] == -1)
            cout << i << ' ';
    cout << endl;
    cout << "enter number of point A";
    cin >> A;
    cout << "enter number of point B";
    cin >> B;
    poisk();
    cout << endl;
    vuvod_res();
    cout << endl;
    system("pause");
 
    return 0;
}
0
-12 / 6 / 4
Регистрация: 19.01.2017
Сообщений: 584
12.09.2019, 21:30
Мне тоже интересно, что за ошибка? Исправьте пожалуйста

Добавлено через 3 минуты
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
//программа ввода системы односторонних дорог
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include "MODYL_2.cpp"
#define n 20 //максимальное число городов
char z[n][n]; //массив названий городов
 
struct listinc
{int town;
listinc *next;
};
 
int input(listinc *adj[], int N, FILE*fp) //ввод информации о системе дорог
{ char city[n];
listinc *b;
int r,i,g,j=0;
for (i = 0; i < N; i++)
    z[i][0] = '\0';
 
while(!feof(fp))
    {
        fscanf(fp, "%s", city);         //ввод названия города-начала дороги
        for(i=0,r=0;i<j&&!r;i++)
            if(!strcmp(city,z[i]))r=1;
        if(r)i--;                       //если город уже есть в списке
        else
            {i=j; j++; strcpy(z[i],city);}  //добавить город в список городов
        b=adj[i];
        adj[i]=new listinc;             //добавление нового эл-та к списку смежности i вершины
        fscanf(fp, "%s", city);         //ввод названия города-конца дороги
        for(g=0, r=0; g<j&&!r;g++)
            if(!strcmp(city,z[g]))r=1;
        if(r)g--;                       //если город уже есть в списке
        else
            {g=j; j++; strcpy(z[g],city);}  //добавить город в список городов
        adj[i]->town=g;                 //в список смежности i города занести номер смежной верншины
        adj[i]->next=b;
    }
if(j<N) 
{
    if (!j)return -3;                   //пустая система дорог
    else return -2;                     //есть изолированные города
}   
else return -1;                         //введён связный орграф
}
 
int search_way(int k, int N, listinc *adj[])    //поиск пути
{
    int i, v, u, flag = 1;
    listinc *use;
    char city1[10], city2[10];
    scanf("%s city1= \n", city1);               //ввод двух вершин, между
    scanf("%s city2= \n", city2);               //которыми нужно найти путь
 
}
 
void main()
{   FILE*fn;
    FILE*fp;
    FILE*f;
    listinc *adj[n];
    int N,r,i,flag,result;
    fn=fopen("system.txt", "r");
    fp = fopen("output.txt", "w");
    f = fopen("file.txt", "r");
    if (fscanf(fn, "%d",&N)!=EOF)           //ввод числа городов
    {
        if (N > 1)
        {
            for (i = 0; i < n; i++)
                adj[i] = NULL;                  //создание пустого списка смежности
            r = input(adj, N, fn);              //ввод системы дорог
            for (i = 0; !feof(f) && i < n; i++) //ввод мн-ва городов,
                fscanf(f, "%s", z[i]);          //через которые не пройдёт путь
            if (r == -1)
            {
                if (N == 2)
                {
                    //поиск пути при N=2
                }
                else
                {
                    for (i = 0, flag = 0; i < N&&!flag; i++)
                        flag = search_way(i, N, adj);   //поиск пути
                    result = flag;
                }
            }
            if (r == -2) result = 0;            //пустая система дорог
            if (r == -3) result = 0;            //есть изолированные города
            if (result){ fprintf(fp, "\n путь найден \n");  /*нужно рапечатать стек*/ }
            else fprintf(fp, "\n такого пути не существует \n");
        }
        else fprintf(fp, "\n это не система дорог \n");
    }
    else fprintf(fp, "\n файл не открыт\n");        //нет даже количества городов
fclose(fn);
fclose(fp);
fclose(f);
}
Добавлено через 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
#include <stdio.h>
#include <conio.h>
#define NMAX 20
#define RMAX 20
int g1[NMAX][NMAX],
g2[NMAX],
n;
 
void VVOD_MATR_SM(void)
{int i,j;
printf(" Vvedite matricy cmeznosti: \n");
printf(" |");
for(j=0;j<n;j++) printf("%d ",j);
putchar('\n');
for(i=0;i<2*n+2;i++) putchar('-');
for(i=0;i<n;i++)
{printf("\n %d|",i);
for(j=0;j<n;j++) scanf("%d",&g1[i][j]);
}
putchar('\n');
}
 
main()
{int i,j;
printf("\n vvedite kol-vo vershin:");
scanf("%d",&n);
VVOD_MATR_SM();
getch();
return 0;
}
0
-12 / 6 / 4
Регистрация: 19.01.2017
Сообщений: 584
13.09.2019, 22:10
Что нужно исправить?
0
-12 / 6 / 4
Регистрация: 19.01.2017
Сообщений: 584
14.09.2019, 15:38
Помогите соединить, или исправить программу пожалуйста.

Добавлено через 2 часа 59 минут
Можете перевести на C++

Pascal
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
uses crt;
type matr=array[1..100,1..100] of integer;
     gor=array[1..100] of integer;
var s:matr;
Q,goroda:gor;
 
i,n,m,t,i_st,i_end,A,B:integer;
 
procedure matr_smezh;
var i,j:integer;
begin
randomize;
for i:=1 to n do
begin
     for j:=1 to n do
     begin
     s[i,j]:=random(2);
     end;
end;
for i:=1 to n do
begin
s[i,i]:=0;
for j:=1 to n do
begin
s[j,i]:=s[i,j];
end;
end;
end;
 
procedure vuvod();
var i,j:integer;
begin
for i:=1 to n do
begin
     for j:=1 to n do
     begin
     write(s[i,j],'   ');
     end;
writeln;
end;
end;
 
procedure poisk;
var i:integer;
begin
goroda[A]:=200;
Q[1]:=A; i_st:=1; i_end:=2;
while i_st<i_end do begin
for i:=1 to n do
if (goroda[i]=0) and (s[Q[i_st],i]=1) then begin
Q[i_end]:=i; inc(i_end); goroda[i]:=Q[i_st];
end;
inc(i_st);
end;
end;
 
procedure vuvod_res();
var i:integer;
begin
if goroda[B]=0 then writeln('Пути нет')
else
begin
Q[1]:=B; i_end:=2; t:=goroda[B];
while t<>A do begin
Q[i_end]:=t; inc(i_end); t:=goroda[t];
end;
Q[i_end]:=A;
for i:=i_end downto 1 do write(Q[i],' ');
end;
end; 
 
begin
clrscr;
writeln ('Введите количество вершин графа');
readln(n);
writeln('Введите количество непроходимых вершин');
readln(m);
writeln('Введите вершины');
for i:=1 to m do begin
readln(t); goroda[t]:=-1;
end;
matr_smezh;
writeln('матрица смежности');
vuvod();
writeln;
for i:=1 to n do 
if goroda[i]=-1 then write(i,' ');
writeln;
writeln ('Введите номер вершины А');
read(A);
writeln ('Введите номер вершины B');
read(B);
poisk;
writeln;
vuvod_res();
writeln;
readln;
end.
0
490 / 286 / 129
Регистрация: 30.10.2018
Сообщений: 1,309
14.09.2019, 15:40
Цитата Сообщение от Like_society Посмотреть сообщение
Можете перевести на C++
Для этого нужно отдельную тему.
0
-12 / 6 / 4
Регистрация: 19.01.2017
Сообщений: 584
14.09.2019, 22:43
kitsoRik, понял.

Добавлено через 1 час 26 минут
Поднять тему.

Добавлено через 5 часов 33 минуты
Исправьте пожалуйста, либо переведите пожалуйста на C++
0
-12 / 6 / 4
Регистрация: 19.01.2017
Сообщений: 584
15.09.2019, 15:24
поднять тему

Добавлено через 27 минут
поднять тему

Добавлено через 1 час 26 минут
Поднять тему.

Добавлено через 53 минуты
Поднять тему.

Добавлено через 36 минут
Поднять тему.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.09.2019, 15:24
Помогаю со студенческими работами здесь

Найти путь, соединяющей города А и В и не проходящий через заданное множество городов
Задана система односторонних дорог. Найти путь, соединяющей города А и В и не проходящий через заданное множество городов. Знаю,что на...

Найти путь максимальной длины, и проходящий через заданное множество вершин
5)Дано бинарное дерево. Найти путь максимальной длины, и проходящий через заданное множество вершин.

Найти в дереве путь максимальной длины, и проходящий через заданное множество вершин
Дано бинарное дерево. Найти путь максимальной длины, и проходящий через заданное множество вершин.

Найти путь соединяющий города А и В
Задана система односторонних дорог. Найти путь соединяющий города А и В и не проходящий через заданное множество городов. Помогите...

Найти кратчайший маршрут, начинающийся в 1-м городе и проходящий через все остальные города
Имеется n городов. Некоторые из них соединены дорогами известной длины. Вся система дорог задана квадратной матрицей порядка n, элемент аij...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru