문제
각 칸마다 색이 칠해진 2차원 격자 보드판이 있습니다. 그중 한 칸을 골랐을 때, 위, 아래, 왼쪽, 오른쪽 칸 중 같은 색깔로 칠해진 칸의 개수를 구하려고 합니다.
보드의 각 칸에 칠해진 색깔 이름이 담긴 이차원 문자열 리스트 board와 고른 칸의 위치를 나타내는 두 정수 h, w가 주어질 때 board[h][w]와 이웃한 칸들 중 같은 색으로 칠해져 있는 칸의 개수를 return 하도록 solution 함수를 완성해 주세요.
이웃한 칸들 중 몇 개의 칸이 같은 색으로 색칠되어 있는지 확인하는 과정은 다음과 같습니다.
- 정수를 저장할 변수 n을 만들고 board의 길이를 저장합니다.
- 같은 색으로 색칠된 칸의 개수를 저장할 변수 count를 만들고 0을 저장합니다.
- h와 w의 변화량을 저장할 정수 리스트 dh, dw를 만들고 각각 [0, 1, -1, 0], [1, 0, 0, -1]을 저장합니다.
- 반복문을 이용해 i 값을 0부터 3까지 1 씩 증가시키며 아래 작업을 반복합니다.
- 체크할 칸의 h, w 좌표를 나타내는 변수 h_check, w_check를 만들고 각각 h + dh[i], w + dw[i]를 저장합니다.
- h_check가 0 이상 n 미만이고 w_check가 0 이상 n 미만이라면 다음을 수행합니다.
- board[h][w]와 board[h_check][w_check]의 값이 동일하다면 count의 값을 1 증가시킵니다.
- count의 값을 return합니다.
- 위의 의사코드와 작동방식이 다른 코드를 작성해도 상관없습니다.
입출력 예시
풀이
#include <string>
#include <vector>
using namespace std;
int solution(vector<vector<string>> board, int h, int w) {
int count = 0;
int n = board.size(); // board의 크기 (조건 : 가로 크기 = 세로 크기)
vector<int> dh = {-1, 0, 0, 1};
vector<int> dw = {0, -1, 1, 0};
for (int i = 0; i < 4; i++){
int h_check = h + dh[i];
int w_check = w + dw[i];
if ((0 <= h_check && 0 <= w_check) && (h_check < n && w_check < n)) {
if (board[h][w] == board[h_check][w_check])
count++;
}
}
return count;
}
'🐸 Problem Solving > Programmers' 카테고리의 다른 글
[Programmers/C++] [PCCE 기출문제] 10번 / 데이터 분석 (0) | 2024.06.14 |
---|---|
[Programmers/C++] [PCCE 기출문제] 8번 / 창고 정리 (0) | 2024.06.14 |
[Programmers/C++] [PCCE 기출문제] 7번 / 가습기 (0) | 2024.06.13 |