-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathKeypad.kt
114 lines (93 loc) · 5.04 KB
/
Keypad.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// https://programmers.co.kr/learn/courses/30/lessons/67256?language=kotlin
// 2020 카카오 인턴십
// 키패드 누르기
// 스마트폰 전화 키패드의 각 칸에 다음과 같이 숫자들이 적혀 있습니다.
// 1 2 3
// 4 5 6
// 7 8 9
// * 0 #
// 이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
// 맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.
// 엄지손가락은 상하좌우 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 해주세요.
// 입출력 예
// numbers hand result
// [1, 3, 4, 5, 8, 2, 1, 4, 5, 9, 5] "right" "LRLLLRLLRRL"
// [7, 0, 8, 2, 8, 3, 1, 5, 7, 6, 2] "left" "LRLLRRLLLRR"
// [1, 2, 3, 4, 5, 6, 7, 8, 9, 0] "right" "LLRLLRLLRL"
// 입출력 예에 대한 설명
// 입출력 예 #1
// 순서대로 눌러야 할 번호가 [1, 3, 4, 5, 8, 2, 1, 4, 5, 9, 5]이고, 오른손잡이입니다.
// 왼손 위치 오른손 위치 눌러야 할 숫자 사용한 손 설명
// * # 1 L 1은 왼손으로 누릅니다.
// 1 # 3 R 3은 오른손으로 누릅니다.
// 1 3 4 L 4는 왼손으로 누릅니다.
// 4 3 5 L 왼손 거리는 1, 오른손 거리는 2이므로 왼손으로 5를 누릅니다.
// 5 3 8 L 왼손 거리는 1, 오른손 거리는 3이므로 왼손으로 8을 누릅니다.
// 8 3 2 R 왼손 거리는 2, 오른손 거리는 1이므로 오른손으로 2를 누릅니다.
// 8 2 1 L 1은 왼손으로 누릅니다.
// 1 2 4 L 4는 왼손으로 누릅니다.
// 4 2 5 R 왼손 거리와 오른손 거리가 1로 같으므로, 오른손으로 5를 누릅니다.
// 4 5 9 R 9는 오른손으로 누릅니다.
// 4 9 5 L 왼손 거리는 1, 오른손 거리는 2이므로 왼손으로 5를 누릅니다.
// 5 9 - -
// 따라서 "LRLLLRLLRRL"를 return 합니다.
// 입출력 예 #2
// 왼손잡이가 [7, 0, 8, 2, 8, 3, 1, 5, 7, 6, 2]를 순서대로 누르면 사용한 손은 "LRLLRRLLLRR"이 됩니다.
// 입출력 예 #3
// 오른손잡이가 [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]를 순서대로 누르면 사용한 손은 "LLRLLRLLRL"이 됩니다.
class Solution {
fun solution(numbers: IntArray, hand: String): String {
var answer = ""
var keypad : Map<Int, Array<Int>> = mapOf(
1 to arrayOf(1, 1)
, 2 to arrayOf(1, 2)
, 3 to arrayOf(1, 3)
, 4 to arrayOf(2, 1)
, 5 to arrayOf(2, 2)
, 6 to arrayOf(2, 3)
, 7 to arrayOf(3, 1)
, 8 to arrayOf(3, 2)
, 9 to arrayOf(3, 3)
, 0 to arrayOf(4, 2)
)
var left = arrayOf(4, 1)
var righ = arrayOf(4, 3)
for(i in numbers){
var next = keypad.get(i)?:arrayOf(0,0)
if(next[1] == 1) {
left = next
answer += "L";
continue;
} else if(next[1] == 3) {
righ = next
answer += "R"
continue;
}
var lx = if(left[0] > next[0]) left[0]-next[0] else next[0]-left[0]
var ly = if(left[1] > next[1]) left[1]-next[1] else next[1]-left[1]
var rx = if(righ[0] > next[0]) righ[0]-next[0] else next[0]-righ[0]
var ry = if(righ[1] > next[1]) righ[1]-next[1] else next[1]-righ[1]
var ldist = lx + ly
var rdist = rx + ry
if(ldist > rdist || ldist == rdist && hand == "right") {
righ = next
answer += "R"
} else {
left = next
answer += "L"
}
}
return answer
}
}