2017.07.16【NOIP提高组】模拟赛B组 卫星照片 题解

原题:

https://jzoj.net/senior/#contest/show/2062/0

题目描述:

农夫 John 正在研究他的农场的卫星照片.照片为一个R (1 <=R <= 75) 行 C (1 <= C <= 75) 列的字符矩阵表示.如下图:

..................
..#####.......##..
..#####......##...
..................
#.......###.....#.
#.....#####....... 

图上的一块相连通的 "#" 表示一群奶牛或一个房间, 两个子"#" 连通的意思是说左右或上下相连.而下面的两块则是分开的:

....
.#..
..#.
....

John现在根据卫星照片上的的这些"#"块的形状来判断哪些是牛群,哪些是房间.如果一个"#"块形状一个内部和边全部都是“#”的矩形,则是房间,如果一个连通块只有一个“#”,也是房间.其它的则认为都是牛群.在第一个图中,有三个房间 ( 2x1, 2x5, and 1x1)和2群牛.
请根据输入文件中的数据,统计出房间数和牛群数.数据中牛群不会包围另一个牛群或房间.

输入:

  • 第一行,两个整数: R 和 C.
  • 和 2..R+1行: 第 i+1 行表示照片的第 i 行情况,由 C 字符组成.

输出:

  • 第一行: 房间数.
  • 第二行: 牛群数.

样例输入:

5 8
#####..#
#####.##
......#.
.###...#
.###..##

样例输出;

2
2

分析:

爆搜,找到每一个‘#’块,判断它是不是矩阵即可

实现:

uses math;
const
        dx:array[1..4]of longint=(-1,0,1,0);
        dy:array[1..4]of longint=(0,1,0,-1);
var
        s:char;
        bz:array[0..79,0..79]of boolean;
        n,m,i,j,minx,maxx,miny,maxy,tot,r,c:longint;
        h:array[0..7001,0..2]of longint;
procedure bfs(p,q:longint);
var
        i,t,w,x,y:longint;
begin
        bz[p,q]:=false;
        t:=1;
        w:=1;
        h[1,1]:=p;
        h[1,2]:=q;
        repeat
                for i:=1 to 4 do
                begin
                        x:=h[t,1]+dx[i];
                        y:=h[t,2]+dy[i];
                        if (x>0)and(x<=m)and(y>0)and(y<=n)and(bz[x,y]) then
                        begin
                                inc(w);
                                inc(tot);
                                h[w,1]:=x;
                                h[w,2]:=y;
                                minx:=min(minx,x);
                                maxx:=max(maxx,x);
                                miny:=min(miny,y);
                                maxy:=max(maxy,y);
                                bz[x,y]:=false;
                        end;
                end;
                inc(t);
        until t>w;
end;
begin
        readln(m,n);
        for i:=1 to m do
        begin
                for j:=1 to n do
                begin
                        read(s);
                        if s='#' then bz[i,j]:=true;
                end;
                readln;
        end;
        for i:=1 to m do
                for j:=1 to n do
                        if bz[i,j] then
                        begin
                                tot:=1;
                                minx:=i;
                                maxx:=i;
                                miny:=j;
                                maxy:=j;
                                bfs(i,j);
                                if (maxx-minx+1)*(maxy-miny+1)=tot then inc(r)
                                else inc(c);
                        end;
        writeln(r);
        writeln(c);
end.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容