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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.67
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
#1

Задача про минимальный путь в лабиринте. - C++

25.11.2011, 19:03. Просмотров 2212. Ответов 7
Метки нет (Все метки)

Вот собственно сама задача:


Разработать программу, которая ищет минимальный путь в лабиринте. Лабиринт представляет собой матрицу 10х10. Клетки, по которым можно передвигаться, заполнены единицами. Клетки, через которые проходить нельзя, заполнены нулями. Необходимо найти кратчайший путь из верхней левой в правую нижнюю клетку.


И мой код. Но некоторые тесты он не проходит. Нужно помочь добить ее до 100%. Очень прошу помочь, т.к. в универе никто толком нормально помочь не может(вернее не хочет)...

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
#include<iostream>
#include<fstream>
using namespace std;
 
void main()
{
    int x, y ;  // размеры матрицы
    ifstream in;
    in.open("input.txt");
    ofstream  out;
    out.open("output.txt"); 
    in>>x>>y;
    int **b=new int*[x];
    for(int i=0; i<x; i++)   
        b[i] = new int[y];
    int **a=new int*[x];
    for (int i=0;i<x;i++)
    {
        a[i]=new int[y];
        for (int j=0;j<y;j++)
            in>>a[i][j];
    } 
    in.close();
    if(a[0][0]==0 && a[x-1][y-1]==0)
    {
        out<<"wrong matrix!"<<endl; 
    }
 
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            b[i][j]=0;
        }
    }
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            if(a[i][j]==0)
                a[i][j]=2;
            else
                a[i][j]=1;
        }
    }
 
 
 
    int k=1;
    //b[0][0]=k;
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            if (i!=0 && j!=0) {
                k=a[i][j]+min(b[i-1][j], b[i][j-1]);
                b[i][j]=k+1;
                k++; 
            } 
        }
    }
    out<<b[x-1][y-1]; 
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.11.2011, 19:03
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Задача про минимальный путь в лабиринте. (C++):

Как найти кратчайший путь в лабиринте? - C++
Чтобы найти кратчайший путь в лабиринте использую волновой алгоритм, его сделал, но вот кратчайший путь не получается восстановить. ...

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

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

Задача "Ладья в Лабиринте" - C++
Ладья – это шахматная фигура, которая за один ход может переместиться на любое количество клеток по горизонтали или вертикали. При этом она...

Найти минимальный путь на земельном участке вдоль ограждения - C++
Земельный участок является прямоугольником со сторонами А и В. На границе заданы точки 1 и 2 с координатами (X1; Y1) и (X2; Y2)...

Минимальный путь из левой верхней в правую нижнюю клетку таблицы. - C++
Не могу понять в чем ошибка...помогите. Химическая тревога (Время: 1 сек. Память: 16 Мб Сложность: 50%) Произошло радиоактивное...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
20.12.2011, 01:13  [ТС] #2
A2 Разработать программу, которая ищет минимальный путь в лабиринте. Лабиринт представляет собой матрицу 10х10. Клетки, по которым можно передвигаться, заполнены единицами. Клетки, через которые проходить нельзя, заполнены нулями. Необходимо найти кратчайший путь из верхней левой в правую нижнюю клетку.




Учитель сказал, что это неправильное решение...Хотя вроди норм работает.
Гляньте, пжл!!!!!Горит очень сильно!!!!Умоляю!!!!!!Подправьте код!!!!!!




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
#include<iostream>
#include<fstream>
using namespace std;
 
void main()
{
    int x, y ;  // размеры матрицы
    ifstream in;
    in.open("input.txt");
    ofstream  out;
    out.open("output.txt"); 
    in>>x>>y;
    int **b=new int*[x];
    for(int i=0; i<x; i++)   
        b[i] = new int[y];
    int **a=new int*[x];
    for (int i=0;i<x;i++)
    {
        a[i]=new int[y];
        for (int j=0;j<y;j++)
            in>>a[i][j];
    } 
    in.close();
    if(a[0][0]==0 && a[x-1][y-1]==0)
    {
        out<<"wrong matrix!"<<endl; 
    }
 
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            b[i][j]=0;
        }
    }
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            if(a[i][j]==0)
                a[i][j]=2;
            else
                a[i][j]=1;
        }
    }
 
 
 
    int k=1;
    //b[0][0]=k;
    for(int i=0; i<x; i++)
    {
        for(int j=0; j<y; j++)
        {
            if (i!=0 && j!=0) {
                k=a[i][j]+min(b[i-1][j], b[i][j-1]);
                b[i][j]=k+1;
                k++; 
            } 
        }
    }
    out<<b[x-1][y-1]; 
}
Добавлено через 3 часа 21 минуту
Помогите, ради всего святого!!!!!!!!!!!!!!!!!!!!
0
CyBOSSeR
Эксперт C++
2302 / 1672 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
20.12.2011, 01:23 #3
Цитата Сообщение от vikichocolate Посмотреть сообщение
Гляньте, пжл!!!!!Горит очень сильно!!!!Умоляю!!!!!!Подправьте код!!!!!!
Раз уж горит, то, думаю, стоит обратится во Фриланс, там Вам помогут за небольшую плату.
0
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
20.12.2011, 01:26  [ТС] #4
туда обращаются без какого-либо кода. я эту задачу уже прошу помочь мне сделать месяц, наверное. но никто вообще не хочет помогать...

сама работаю, чтобы есть было что...
0
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2011, 02:19 #5
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
#include<iostream>
#include<fstream>
using namespace std;
 
void main()
{
        int x, y ;  // размеры матрицы
        ifstream in;
        in.open("input.txt");
        ofstream  out;
        out.open("output.txt"); 
        in>>x>>y;
        int **b=new int*[x];
        for(int i=0; i<x; i++)   
                b[i] = new int[y];
        int **a=new int*[x];
        for (int i=0;i<x;i++)
        {
                a[i]=new int[y];
                for (int j=0;j<y;j++)
                        in>>a[i][j];
        } 
        in.close();
        if(a[0][0]==0 && a[x-1][y-1]==0)
        {
                out<<"wrong matrix!"<<endl; 
        }
 
        for(int i=0; i<x; i++)
        {
                for(int j=0; j<y; j++)
                {
                        b[i][j]=0;
                }
        }
        b[0][0]=1;
         int k=1;
        while(true)
        {
            bool fl=false;
            int i, j;
            for(i=0; i<x; i++)
                for(j=0; j<y; j++)
                    if(b[i][j]==k)
                    {
                        if(i>0 && a[i-1][j]==0 && b[i-1][j]==0)
                        {
                            b[i-1][j]=k+1;
                            fl=true;
                        }
                        if(i<x-1 && a[i+1][j]==0 && b[i+1][j]==0)
                        {
                            b[i+1][j]=k+1;
                            fl=true;
                        }
                        if(j>0 && a[i][j-1]==0 && b[i][j-1]==0)
                        {
                            b[i][j-1]=k+1;
                            fl=true;
                        }
                        if(j<y-1 && a[i][j+1]==0 && b[i][j+1]==0)
                        {
                            b[i][j+1]=k+1;
                            fl=true;
                        }
                    }
            if(!fl)
                break;
            else
                k++;
        }
        if(b[x-1][y-1]==0)
            out<<"No"<<endl;
        else
        {
            out<<b[x-1][y-1];
 
        }
}
Для таких условий матрица 10*10 подойдет и такой вариант. Проверьте на всякий случай - сам на работоспособность не проверял.
Выводит: No - если пути нет, или если есть путь выводит кол-во пройденных клеток (включая верхнюю левую и нижнюю правую).
1
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
20.12.2011, 09:47  [ТС] #6
спасибо, что посмотрели. только можете разъяснить немного ваш код.

просто тест
3 3
110
010
011


он неправильно проходит=(((
0
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.12.2011, 10:01 #7
Вот так проверьте:
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
#include<iostream>
#include<fstream>
using namespace std;
 
void main()
{
        int x, y ;  // размеры матрицы
        ifstream in;
        in.open("input.txt");
        ofstream  out;
        out.open("output.txt"); 
        in>>x>>y;
        int **b=new int*[x];
        for(int i=0; i<x; i++)   
                b[i] = new int[y];
        int **a=new int*[x];
        for (int i=0;i<x;i++)
        {
                a[i]=new int[y];
                for (int j=0;j<y;j++)
                        in>>a[i][j];
        } 
        in.close();
        if(a[0][0]==0 && a[x-1][y-1]==0)
        {
                out<<"wrong matrix!"<<endl; 
        }
 
        for(int i=0; i<x; i++)
        {
                for(int j=0; j<y; j++)
                {
                        b[i][j]=0;
                }
        }
                b[0][0]=1;
         int k=1;
        while(true)
                {
                        bool fl=false;
                        int i, j;
                        for(i=0; i<x; i++)
                                for(j=0; j<y; j++)
                                        if(b[i][j]==k)
                                        {
                                                if(i>0 && a[i-1][j]==1 && b[i-1][j]==0)
                                                {
                                                        b[i-1][j]=k+1;
                                                        fl=true;
                                                }
                                                if(i<x-1 && a[i+1][j]==1 && b[i+1][j]==0)
                                                {
                                                        b[i+1][j]=k+1;
                                                        fl=true;
                                                }
                                                if(j>0 && a[i][j-1]==1 && b[i][j-1]==0)
                                                {
                                                        b[i][j-1]=k+1;
                                                        fl=true;
                                                }
                                                if(j<y-1 && a[i][j+1]==1 && b[i][j+1]==0)
                                                {
                                                        b[i][j+1]=k+1;
                                                        fl=true;
                                                }
                                        }
                        if(!fl)
                                break;
                        else
                                k++;
                }
                if(b[x-1][y-1]==0)
                        out<<"No"<<endl;
                else
                {
                        out<<b[x-1][y-1];
 
                }
}
Выдает кол-во пройденных клеток. Т.е. на тест:
3 3
110
010
011
выдаст 5.
Или Вам нужно что бы вывело в файл:
220
020
022
? Тут двойками обозначен сам минимальный путь.
1
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
20.12.2011, 10:23  [ТС] #8
все! спасибо Вам огромное. месяц мучилась с этой прогой!!!!!!!!!!
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.12.2011, 10:23
Привет! Вот еще темы с ответами:

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

Задача про рюкзак - C++
Всем привет! Есть программа, которая решает задачу про рюкзак. Когда у меня количество &quot;предметов&quot; 5 или 10, то все работает хорошо....

задача про матрицы - C++
не могу написать программу.только начала изучать язык с++.помогите пожалуйста

Задача про банк - C++
Вечер добрый! Прошу помощи, товарищи! Задание на скрине) #include &lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;conio.h&gt; void main() { ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
20.12.2011, 10:23
Ответ Создать тему
Опции темы

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