Предмет: Информатика,
автор: МишкаМашки
ИВТ/ 9 КЛАСС/ ХЕЕЕЛП/ 30 БАЛЛОВ
Лабиринт
Терминатор T101 заблудился в лабиринтах подвальных помещений компании
Cyberdyne Systems. Подвал представляет собой прямоугольную площадку размена NxM
клеток. Каждая клетка может быть проходимой, а может быть непроходимой. У терминатора
есть план подвала, в котором проходимые клетки отмечены точками (“.”), непроходимые –
иксами (символ “x”), текущее положение терминатора отмечено символом “+”. Чтобы
организовать поиски выхода, терминатор должен отметить на своем плане все проходимые
клетки, в которые он может попасть и подсчитать их количество (включая клетку, на
которой он находится в данный момент). Он может ходить только по проходимым клеткам,
совершая каждый переход на одну клетку вверх, вниз, вправо или влево. При этом он не
может выходить за границы заданного прямоугольника.
Входные данные
В первой строке входного файла задается через пробел два числа N и M — размеры подвала,
причем 1 ≤ N ≤ 100, 1 ≤ M ≤ 100. В последующих N строках вводится план лабиринта — по
M символов в строке.
Выходные данные
В выходной файл выведите единственное число — количество достижимых терминатором
клеток.
Пример входного файла
4 6
.x.x..
.xxx..
....xx
x.+.x.
Пример выходного файла
9
Используя эту программу
var a:array [0..101,0..101] of byte;
i,j,n,m,k:byte;
c:char;
procedure labirint(i,j:byte);
begin
if a[i,j]=0 then begin
a[i,j]:=1; k:=k+1;
labirint(i,j-1);
labirint(i,j+1);
labirint(i-1,j);
labirint(i+1,j);
end;end;
begin
readln(n);
for i:= 1 to n do begin
for j:= 1 to n do begin
read(c);
case c of
'*':a[i,j]:=-1;
'.':a[i,j]:=0;
'+':a[i,j]:=1;
end; end;
readln;
end;
readln(i,j);
labirint(i,j);
if a[i,j]=0 then inc(k);
writeln(k);
end.
нужно добавить границы
Ответы
Автор ответа:
0
const
max_length = 10;
type
arr = array [0..max_length, 0..max_length] of byte;
var
a: arr;
i, j, n, m, k, x, y: byte;
c: char;
f: text;
//procedure PrintMatrix(a: arr);
//begin
// for var i := 0 to max_length do
// begin
// writeln;
// for var j := 0 to max_length do
// write(a[i, j], ' ');
// end;
// writeln;
//end;
procedure labirint(i, j: byte);
begin
if (i <= n) and (i >= 0) and (j <= m) and (j >= 0) and (a[i, j] = 0) then begin
a[i, j] := 1;
k := k + 1;
labirint(i, j - 1);
labirint(i, j + 1);
labirint(i - 1, j);
labirint(i + 1, j);
end;
end;
begin
Assign(f, 'input.txt');
Reset(f);
readln(f, n, m);
for i := 0 to n do
begin
for j := 0 to m do
begin
read(f, c);
case c of
'x': a[i, j] := 2;
'.': a[i, j] := 0;
'+':
begin
x := i;
y := j;
a[i, j] := 0;
end;
end;
end;
readln(f);
end;
Close(f);
// PrintMatrix(a);
labirint(x, y);
writeln(k);
// PrintMatrix(a);
end.
инструментарий для дебага оставила. Проверяйте значение символов перед стартом
max_length = 10;
type
arr = array [0..max_length, 0..max_length] of byte;
var
a: arr;
i, j, n, m, k, x, y: byte;
c: char;
f: text;
//procedure PrintMatrix(a: arr);
//begin
// for var i := 0 to max_length do
// begin
// writeln;
// for var j := 0 to max_length do
// write(a[i, j], ' ');
// end;
// writeln;
//end;
procedure labirint(i, j: byte);
begin
if (i <= n) and (i >= 0) and (j <= m) and (j >= 0) and (a[i, j] = 0) then begin
a[i, j] := 1;
k := k + 1;
labirint(i, j - 1);
labirint(i, j + 1);
labirint(i - 1, j);
labirint(i + 1, j);
end;
end;
begin
Assign(f, 'input.txt');
Reset(f);
readln(f, n, m);
for i := 0 to n do
begin
for j := 0 to m do
begin
read(f, c);
case c of
'x': a[i, j] := 2;
'.': a[i, j] := 0;
'+':
begin
x := i;
y := j;
a[i, j] := 0;
end;
end;
end;
readln(f);
end;
Close(f);
// PrintMatrix(a);
labirint(x, y);
writeln(k);
// PrintMatrix(a);
end.
инструментарий для дебага оставила. Проверяйте значение символов перед стартом
Похожие вопросы
Предмет: Информатика,
автор: avramkhachirov
Предмет: Українська мова,
автор: AshleyMiller
Предмет: Английский язык,
автор: dasssha082
Предмет: История,
автор: Аноним
Предмет: Математика,
автор: zinkrav4encko