#Lutece0720. C.S.I.: P15
C.S.I.: P15
Migrated from Lutece 720 C.S.I.: P15
All parts of this problem, including description, images, samples, data and checker, might be broken. If you find bugs in this problem, please contact the admins.
Description
You have been cast as the computer genius hero-of-the-day for the season finale of the show C.S.I.: P15 (coming this fall). Somewhat unsurprisingly,there is that camera feed that needs to be analyzed. The camera in question is recording pictures in HD-9000 quality with extra regression and the stream is then internally matched by a re-inverted isomorphic bit coefficient matrix, then plasma shifted five times for good measure. You then view the feed through Netscape Navigator 4 Platinum Edition. (Note that "internally" is just fancy talk for "inside the camera".)
Unfortunately, a saboteur turned on ASCII mode on the camera and set the camera in picture burst mode. So now all you have is a bunch of still ASCII images. And now,for reasons that will be revealed later in the show, you are to design and implement a deterministic algorithm for counting the number of flowers and birds in a given still image.
The pictures always include the ground,which will show up as a contiguous row of =
characters. The ground will always be the bottom-most row of "ASCII pixels". There will never be anything else on that row (though, on one of the pictures taken before the sabotage there is a stray electron that a someone will accidentally find by zooming in too far, but that is for a later episode).
Air is marked in the feed as a .
(a dot). The ground is the last line of the feed, and it looks like this: ===========
. A flower is defined as any -connected component which consists of characters from the set { |
, /
, \
, -
, @
}, and which is also connected to the ground. Two cells belong to the same -connected component if there is a path between them that goes through elements from the forementioned set only, such that each step in the path is to an -connected neighbour (horizontally, vertically, or diagonally adjacent cell). A bird is an occurence of /\/\
, such that all neighbouring cells are either air or edges of the image. So if you see something that looks like a bird on the ground, it is a flower (possibly an ex-parrot, but that is also a flower for our purposes).
Input
The first line of the input consists of a single integer , the number of test cases. Each of the following cases then begins with a line of two integers separated by a space,the height and width , and ends with lines describing the picture. Each line of the picture has exactly characters. All lines but the last consist of only the following characters: { .
, |
, /
, \
, -
, @
}. The last line consists of =
characters only.
Output
For each test case, output two lines. If the number of flowers is and the number of birds is , the output should read
Flowers: F
Birds: B
Samples
1
12 28
............................
............................
\@/.../\/\..../\/\..........
.|..........................
.|....\@/.........../\/\....
.|.....|.............|......
.|.....|.............|......
.|.....|..\@/....\@/.|......
.|.....|....\..../...|.|-|..
.|.....|.....\../....|.|.|..
.|.....|......\/.....|.|.|..
============================
Flowers: 5
Birds: 2
Resources
IDI Open 2013 Programming Contest