Поиск по этому блогу

понедельник, 20 января 2020 г.

Морской бой - 2

«Морской бой» - игра для двух участников, в которой игроки по очереди называют координаты на неизвестной им карте соперника. Если у соперника по этим координатам имеется корабль, то корабль или его часть «топится», а попавший получает право сделать еще один ход. Цель игрока - первым поразить все корабли противника.«Морской бой» очень популярен среди учеников одной физико-математической школы. Ребята очень любят в него играть на переменах. Вот и сейчас ученики Иннокентий и Емельян начали новую партию.
Правила, по которым ребята расставляют корабли перед началом партии, несколько отличаются от классических. Во-первых, игра происходит на поле размером N×M, а не 10×10. Во-вторых, число кораблей, их размер и форма выбираются ребятами перед партией - так играть намного интереснее.
Емельян уже расставил все свои корабли, кроме одного однопалубного. Такой корабль занимает ровно одну клетку.
Задана расстановка кораблей Емельяна. Найдите число способов поставить оставшийся однопалубный корабль. При этом учитывайте, что по правилам его можно ставить только в ту клетку, все соседние с которой не заняты. В этой задаче соседними считаются клетки, имеющие общую сторону.
Входные данные
Первая строка входного файла INPUT.TXT содержит два числа: N и M (1 ≤ N, M ≤ 100). Последующие N строк описывают игровое поле - каждая из них содержит M символов. Символом «.» (точка) обозначена свободная клетка, символом «*» (звездочка) - занятая кораблем.
Выходные данные
В выходной файл OUTPUT.TXT выведите ответ на задачу.
Примеры
INPUT.TXT
OUTPUT.TXT
1
4 4
****
**..
*...
*...
4
2
4 3
***
...
...
***
0
Решение
var a:array[0..101,0..101]of char;     
j,n,m,i,k:integer;
f,f1:text; 
begin
assign(f,'input.txt'); 
    reset(f); 
     assign(f1,'output.txt'); 
     rewrite(f1); 
    readln(f,n,m);
    k:=0;
for i:=1 to n do begin
 for j:=1 to m do
  read(f,a[i,j]);
  readln(f);
end;
for i:=0 to m+1 do
begin
a[0,i]:='.';a[n+1,i]:='.'; end;
for i:=0 to n+1 do begin
a[i,0]:='.';a[i,m+1]:='.'; end;
for i:=1 to n do
 for j:=1 to m do
 if (a[i,j]='.') and (a[i,j-1]='.') and  (a[i-1,j]='.') and  (a[i,j+1]='.') and (a[i+1,j]='.') then k:=k+1; 
  write(f1,k);close(f1);  close(f);
end.

Комментариев нет:

Отправить комментарий