문제 설명
스마트폰 전화 키패드의 각 칸에 다음과 같이 숫자들이 적혀 있습니다.
이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.
- 엄지손가락은 상하좌우 4가지 방향으로만 이동할 수 있으며 키패드 이동 한 칸은 거리로 1에 해당합니다.
- 왼쪽 열의 3개의 숫자 1, 4, 7을 입력할 때는 왼손 엄지손가락을 사용합니다.
- 오른쪽 열의 3개의 숫자 3, 6, 9를 입력할 때는 오른손 엄지손가락을 사용합니다.
- 가운데 열의 4개의 숫자 2, 5, 8, 0을 입력할 때는 두 엄지손가락의 현재 키패드의 위치에서 더 가까운 엄지손가락을 사용합니다.
4-1. 만약 두 엄지손가락의 거리가 같다면, 오른손잡이는 오른손 엄지손가락, 왼손잡이는 왼손 엄지손가락을 사용합니다.
순서대로 누를 번호가 담긴 배열 numbers, 왼손잡이인지 오른손잡이인 지를 나타내는 문자열 hand가 매개변수로 주어질 때, 각 번호를 누른 엄지손가락이 왼손인 지 오른손인 지를 나타내는 연속된 문자열 형태로 return 하도록 solution 함수를 완성해주세요.
[제한사항]- numbers 배열의 크기는 1 이상 1,000 이하입니다.
- numbers 배열 원소의 값은 0 이상 9 이하인 정수입니다.
- hand는 "left" 또는 "right" 입니다.
- "left"는 왼손잡이, "right"는 오른손잡이를 의미합니다.
- 왼손 엄지손가락을 사용한 경우는 L, 오른손 엄지손가락을 사용한 경우는 R을 순서대로 이어붙여 문자열 형태로 return 해주세요.
https://programmers.co.kr/learn/courses/30/lessons/67256
#include <string>
#include <vector>
#include <iostream>
using namespace std;
string solution(vector<int> numbers, string hand) {
string answer = "";
//keypad 초기화
vector <pair<int, int> > keypad;
keypad.push_back(make_pair(1,3)); //0
keypad.push_back(make_pair(0,0)); //1
keypad.push_back(make_pair(1,0)); //2
keypad.push_back(make_pair(2,0)); //3
keypad.push_back(make_pair(0,1)); //4
keypad.push_back(make_pair(1,1)); //5
keypad.push_back(make_pair(2,1)); //6
keypad.push_back(make_pair(0,2)); //7
keypad.push_back(make_pair(1,2)); //8
keypad.push_back(make_pair(2,2)); //9
//왼손 오른손이 지나간 경로
vector <pair<int, int> > left;
vector <pair<int, int> > right;
left.push_back(make_pair(0,3)); //시작 위치 *
right.push_back(make_pair(2,3)); //시작 위치 #
for (int i=0; i<numbers.size(); i++) {
//1,4,7 무조건 왼손
if (numbers[i] == 1 || numbers[i] == 4 || numbers[i] == 7) {
left.push_back(keypad[numbers[i]]);
answer.push_back('L');
}
//3,6,9 무조건 오른손
else if (numbers[i] == 3 || numbers[i] == 6 || numbers[i] == 9) {
right.push_back(keypad[numbers[i]]);
answer.push_back('R');
}
//2,5,8,0 가까운 손
else {
int L_length = abs(keypad[numbers[i]].first-left.back().first)
+ abs(keypad[numbers[i]].second-left.back().second);
int R_length = abs(keypad[numbers[i]].first-right.back().first)
+ abs(keypad[numbers[i]].second-right.back().second);
if(L_length > R_length) {
right.push_back(keypad[numbers[i]]);
answer.push_back('R');
}else if(L_length < R_length) {
left.push_back(keypad[numbers[i]]);
answer.push_back('L');
}else { //거리가 같은 경우
if(hand == "right") {
right.push_back(keypad[numbers[i]]);
answer.push_back('R');
}else {
left.push_back(keypad[numbers[i]]);
answer.push_back('L');
}
}
}
}
return answer;
}
'Coding Test' 카테고리의 다른 글
[카카오]비밀지도 (0) | 2021.12.26 |
---|---|
[카카오]신규 아이디 추천 (0) | 2021.12.26 |
[BFS]04-백준 2178 미로탐색 (0) | 2019.10.02 |
[BFS]03-백준 1012 유기농 배추 (0) | 2019.09.28 |
[BFS]02-백준 1697 숨바꼭질 (0) | 2019.09.24 |