Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C++ Заменить каждую букву и знак пунктуации тем, который находится непосредственно слева от него на клавиатуре https://www.cyberforum.ru/ cpp-beginners/ thread391767.html
С++ Обычная ошибка при наборе состоит в том что вы помещаете руки на клавиатуре на 1 ряд правее верной позиции. Тогда "Q" будет печататься как "W", "J" печататься как "K", и т.д. Ваша задача состоит в расшифровке сообщения набранного таким образом. ВХОДНЫЕ ДАННЫЕ. входные данные состоят из нескольких строк текста. Каждая строка может содержать цифры, пробелы, прописные буквы на клавиатуре...
C++ Заполнение динамической матрицы по спирали из центра
Дано число n. Создайте массив int A и заполните его по спирали начиная с числа 0 в центральной клетке A. Спираль выходит вверх, далее закручивается против часовой стрелки. Выведите массив на экран, отводя на вывод каждого числа ровно 3 символа. массив динамический. ссылаясь на инет источники создал примерно начало программы, но подскажите, на верном пути или нет? и еще, объясните что такое...
C++ хитрая константа не даёт создать обычный массив https://www.cyberforum.ru/ cpp-beginners/ thread391749.html
Почему я не могу создать обычный массив, указав константу в качестве количества элементов? int n=10; const int N(n); //N вроде как константа //действительно получает значение 10 int A; //error C2057: требуется константное выражение //error C2466: невозможно выделить память
C++ Массивы и натуральные числа Помогите пожалуйста написать программу. Ввести натуральное число n. а) Записать в массив только те делители числа n, которые являются палиндромами. б) Вывести все делители числа n, у которых последняя цифра наименьшая. Заранее спасибо. https://www.cyberforum.ru/ cpp-beginners/ thread391748.html
Класс "Список", функция добавления элемента в конец C++
#include <iostream> #include <cstring> using namespace std; struct myElem { char *line; myElem *next; myElem(const char* str)
C++ Вывести все целые числа, расположенные между заданными Даны два целых числа A и B (A < B). Вывести все целые числа, расположенные между данными числами (включая сами эти числа), в порядке их убывания. Использовать цикл for. #include <stdio.h> #include <conio.h> void main() { int a,b,i; clrscr(); printf("vvedite a: "); scanf("%i",&a); https://www.cyberforum.ru/ cpp-beginners/ thread391730.html
C++ Проверьте, пожалуйста, правильность составленного мной алгоритма) Вот код: #include <iostream> #include <stdlib.h> #include <stdio.h> int main() { FILE *fp; int n, i, min, number, sum, a; char fname = "D:\\file.txt"; https://www.cyberforum.ru/ cpp-beginners/ thread391728.html #pragma once C++
Можно ли считать директиву #pragma once полноценно заменой техники #ifndef MYFILE_H #define MYFILE_H ... #end if
C++ Ошибка сегментации. Здравствуйте, дорогие форумчане! Тут такое дело, есть программа, код приведен ниже, там есть некоторый массив D. После компиляции программы вместе с этим массивом, программа вылетает, выдав ошибку Без неё, программа компилируется, выполняет циклы и успешно завершает работу. Проверил отладчиком, выдало "ошибку сегментации". Увеличил размер стека, тож не помогло. Чё делать? #include... https://www.cyberforum.ru/ cpp-beginners/ thread391684.html C++ Функиции в С. https://www.cyberforum.ru/ cpp-beginners/ thread391683.html
Ребята, помогите, нужно написать функцию дано три матрици А, В и С, третьего порядка, и число Р.Найти АВС в степени Р.
Строковые переменные. C++
Дано последовательность, что состоит из 1-30 слов, в каждом слове 1-5 букв, все слова разделены запятой, в конце точка. Напечатать все слова, буквы которых упорядочены за азбукой. Подскажите пожалуйста, как решить?
C++ Удалить некоторые символы из строки https://www.cyberforum.ru/ cpp-beginners/ thread391659.html
Есть строка String^ str = ".5555555.23.234..4.4.4."; требуется удалить точки из строки. Конечная строка должна выглядеть так str = "555555523234444"
Эксперт С++
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
20.12.2011, 02:19 0

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

20.12.2011, 02:19. Показов 8736. Ответов 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]==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 - если пути нет, или если есть путь выводит кол-во пройденных клеток (включая верхнюю левую и нижнюю правую).

Вернуться к обсуждению:
Задача про минимальный путь в лабиринте. C++
1
Заказать работу у эксперта
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.12.2011, 02:19
Готовые ответы и решения:

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

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

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

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

7
20.12.2011, 02:19
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.12.2011, 02:19
Помогаю со студенческими работами здесь

Найти путь в лабиринте
Дан лабиринт, состоящий из N комнат, и информация о возможности перехода из i-ой комнаты в j-ую....

Почему не прорисовывается путь в лабиринте?
Не могу понять почему нормально не прорисовывается путь, путь это нули, вот код using System;...

Найти путь в лабиринте с минимальным количеством поворотов
Как это можно реализовать?

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

0
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru