문제
봄이 오고 있다. 해는 높이 떠서 환하게 빛나고 있다. 사람들은 햇볕을 가리기 위해 블라인드를 내린다.
상근이는 이웃들이 무엇을 하는지를 염탐하고, 이것에 대해서 뒷담화를 하는 주부이다. 올해는 건너편 아파트에 사는 사람들이 블라인드를 얼마나 내리는지를 조사하려고 한다.
모든 창문은 4*4 그리드로 나타낼 수 있고, *를 이용해서 블라인드를 나타낸다. 상근이가 볼 수 있는 창문은 다음 5가지 상태 중 하나이다.
건너편 아파트의 한 층에는 N개의 창문이 있고, 총 M층 건물이다. 현재 건너편 아파트의 창문 상태가 주어졌을 때, 위의 5가지 상태가 각각 몇 번 나오는지 구하는 프로그램을 작성하시오.
입력
첫째 줄에 M과 N이 공백으로 구분해서 주어진다. (1 ≤ M, N ≤ 100)
다음 줄에는 현재 건너편 아파트의 상태가 주어진다. 모든 창문은 문제 설명에 나온 것 처럼 4*4 그리드로 주어진다. 또, 창문과 창문은 '#'를 이용해서 구분한다. 예제 입력 형식을 참고하면 좋다. 아파트의 정보는 5M+1줄, 각 줄은 5N+1개 글자로 이루어져 있다.
출력
출력은 총 5개 숫자이다. 문제 설명에 나온 순서대로 각 블라인드 타입이 몇 개 있는지를 출력한다. 숫자를 모두 합하면 M*N이 되어야 한다.
그림 전체를 생각하지말고 그냥 한 창문에서 첫 문자만의 비교로 이 창문의 형태를 알아 낼 방법을 생각하기.
첫 문자가 . 이라면 0번째 모양의 증가이고 , *인경우 각 1,2,3,4 의 증가가 가능하게 설계.
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int M,N;
int arr[5];
int main(void)
{
cin >> M >> N;
vector vec(5*M+1);
for(int i = 0 ; i < 5*M+1; i++)
{
cin >> vec[i];
}
for(int i = 0; i < 5*M+1; i++)
{
bool check = false;
for(int j = 0; j < 5*N+1; j++)
{
if(vec[i][j] == '*')
{
check = true;
int k = 0;
k++;
while(vec[i+k][j] == '*'){
k++;
}
arr[k]++;
j += 3;
}
else if(vec[i][j] == '.')
{
check = true;
arr[0]++;
j += 3;
}
}
if(check)
{
i+=3;
}
}
for(int s =0; s<5; s++)
{
cout<<arr[s]<<" ";
}
}
'Algorithm' 카테고리의 다른 글
백준 2897번 몬스터 트럭 (0) | 2019.09.30 |
---|---|
백준 10814번 나이순 정렬 (0) | 2019.09.25 |
백준 10988번 팰린드롬인지 확인하기 (0) | 2019.09.19 |
백준 1931번 회의실배정 (0) | 2019.09.17 |
백준 2504번 괄호의 값 (0) | 2019.09.16 |