문제
- 나만의 카카오 성격 유형 검사지를 만들려고 합니다.
- 성격 유형 검사는 다음과 같은 4개 지표로 성격 유형을 구분합니다. 성격은 각 지표에서 두 유형 중 하나로 결정됩니다.
지표 번호 | 성격 유형 |
1번 지표 | 라이언형(R), 튜브형(T) |
2번 지표 | 콘형(C), 프로도형(F) |
3번 지표 | 제이지형(J), 무지형(M) |
4번 지표 | 어피치형(A), 네오형(N) |
- 4개의 지표가 있으므로 성격 유형은 총 16(=2 x 2 x 2 x 2)가지가 나올 수 있습니다. 예를 들어, "RFMN"이나 "TCMA"와 같은 성격 유형이 있습니다.
- 검사지에는 총 n개의 질문이 있고, 각 질문에는 아래와 같은 7개의 선택지가 있습니다.
- 매우 비동의
- 비동의
- 약간 비동의
- 모르겠음
- 약간 동의
- 동의
- 매우 동의
- 각 질문은 1가지 지표로 성격 유형 점수를 판단합니다.
- 예를 들어, 어떤 한 질문에서 4번 지표로 아래 표처럼 점수를 매길 수 있습니다.
선택지 | 성격 유형 점수 |
매우 비동의 | 네오형 3점 |
비동의 | 네오형 2점 |
약간 비동의 | 네오형 1점 |
모르겠음 | 어떤 성격 유형도 점수를 얻지 않습니다 |
약간 동의 | 어피치형 1점 |
동의 | 어피치형 2점 |
매우 동의 | 어피치형 3점 |
- 이때 검사자가 질문에서 약간 동의 선택지를 선택할 경우 어피치형(A) 성격 유형 1점을 받게 됩니다. 만약 검사자가 매우 비동의 선택지를 선택할 경우 네오형(N) 성격 유형 3점을 받게 됩니다.
- 위 예시처럼 네오형이 비동의, 어피치형이 동의인 경우만 주어지지 않고, 질문에 따라 네오형이 동의, 어피치형이 비동의인 경우도 주어질 수 있습니다.
하지만 각 선택지는 고정적인 크기의 점수를 가지고 있습니다.
- 매우 동의나 매우 비동의 선택지를 선택하면 3점을 얻습니다.
- 동의나 비동의 선택지를 선택하면 2점을 얻습니다.
- 약간 동의나 약간 비동의 선택지를 선택하면 1점을 얻습니다.
- 모르겠음 선택지를 선택하면 점수를 얻지 않습니다.
- 검사 결과는 모든 질문의 성격 유형 점수를 더하여 각 지표에서 더 높은 점수를 받은 성격 유형이 검사자의 성격 유형이라고 판단합니다. 단, 하나의 지표에서 각 성격 유형 점수가 같으면, 두 성격 유형 중 사전 순으로 빠른 성격 유형을 검사자의 성격 유형이라고 판단합니다.
- 질문마다 판단하는 지표를 담은 1차원 문자열 배열 survey와 검사자가 각 질문마다 선택한 선택지를 담은 1차원 정수 배열 choices가 매개변수로 주어집니다. 이때, 검사자의 성격 유형 검사 결과를 지표 번호 순서대로 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ survey의 길이 ( = n) ≤ 1,000
- survey의 원소는 "RT", "TR", "FC", "CF", "MJ", "JM", "AN", "NA" 중 하나입니다.
- survey[i]의 첫 번째 캐릭터는 i+1번 질문의 비동의 관련 선택지를 선택하면 받는 성격 유형을 의미합니다.
- survey[i]의 두 번째 캐릭터는 i+1번 질문의 동의 관련 선택지를 선택하면 받는 성격 유형을 의미합니다.
- choices의 길이 = survey의 길이
- choices[i]는 검사자가 선택한 i+1번째 질문의 선택지를 의미합니다.
- 1 ≤ choices의 원소 ≤ 7
입출력 예
풀이
class Solution {
fun solution(survey: Array<String>, choices: IntArray): String {
var answer: String = ""
val scoreArr = intArrayOf(3, 2, 1, 0, 1, 2, 3)
var eachScore = mutableMapOf(
//key-value로 각각을 받음
"R" to 0, "T" to 0,
"C" to 0, "F" to 0,
"J" to 0, "M" to 0,
"A" to 0, "N" to 0,
)
for (i in survey.indices) {
val s = survey[i]
val str = if (choices[i] < 4) s[0] else s[1]
//2개로 나눠서 점수 부여
if (choices[i] == 4) continue //4 (0점) 이면 다시
eachScore[str.toString()] = eachScore.getOrDefault(str.toString(), 0) + scoreArr[choices[i] - 1]
}
answer += if (eachScore.getOrDefault("R", 0) >= eachScore.getOrDefault("T", 0)) "R" else "T"
answer += if (eachScore.getOrDefault("C", 0) >= eachScore.getOrDefault("F", 0)) "C" else "F"
answer += if (eachScore.getOrDefault("J", 0) >= eachScore.getOrDefault("M", 0)) "J" else "M"
answer += if (eachScore.getOrDefault("A", 0) >= eachScore.getOrDefault("N", 0)) "A" else "N"
return answer
}
}
해설
더보기
val scoreArr = intArrayOf(3, 2, 1, 0, 1, 2, 3)
var eachScore = mutableMapOf(
//key-value로 각각을 받음
"R" to 0, "T" to 0,
"C" to 0, "F" to 0,
"J" to 0, "M" to 0,
"A" to 0, "N" to 0,
)
scoreArr에 1-7값을 저장
eachScore에 Map으로 각 알파벳에 맞는 key값을 주고 value값에 더할 생각으로 만듬
for (i in survey.indices) {
val s = survey[i]
val str = if (choices[i] < 4) s[0] else s[1]
...
survey의 값을 돌면서
s로 survey의 두개 문자를 한개로 나눠서
choices의 값이 4보다 작으면 s값 중 앞에 알파벳을 아니면 뒤에 알파벳을 받는다.
...
if (choices[i] == 4) continue //4 (0점) 이면 다시
eachScore[str.toString()] = eachScore.getOrDefault(str.toString(), 0) + scoreArr[choices[i] - 1]
...
choices의 값 4는 상관없음(0)점이여서 continue로 패스
위에서 만든 map으로 각 알파벳을 받은 곳(eachScore)에 해당하는 알파벳에 점수(value)를 더한다.
map.getOrDefault(Key, DefaultValue)를 사용했다. 오늘 알게 된 내용으로 key값이 없으면 DefaultValue값을 준다.
answer += if (eachScore.getOrDefault("R", 0) >= eachScore.getOrDefault("T", 0)) "R" else "T"
answer += if (eachScore.getOrDefault("C", 0) >= eachScore.getOrDefault("F", 0)) "C" else "F"
answer += if (eachScore.getOrDefault("J", 0) >= eachScore.getOrDefault("M", 0)) "J" else "M"
answer += if (eachScore.getOrDefault("A", 0) >= eachScore.getOrDefault("N", 0)) "A" else "N"
각 value값을 비교해서 어떤 알파벳을 가져올지 정하고
survey에 해당하지 않으면 앞에 알파벳을 가져온다.
다른사람의 풀이
// leefree3
class Solution {
fun solution(survey: Array<String>, choices: IntArray): String {
val scoreMap = mutableMapOf("RT" to 0, "CF" to 0, "JM" to 0, "AN" to 0)
survey.forEachIndexed { index, key ->
if (scoreMap.keys.contains(key)) {
scoreMap[key] = scoreMap[key]!! + choices[index] - 4
} else {
scoreMap[key.reversed()] = scoreMap[key.reversed()]!! - (choices[index] - 4)
}
}
var answer = ""
scoreMap.forEach { (key, value) -> answer += if(value > 0) key[1] else key[0] }
return answer
}
}
map으로 2개씩 묶어둔 뒤
정수와 음수를 줘서 구분하는 생각은 못했다..
'프로그래머스' 카테고리의 다른 글
[프로그래머스_Kotlin] 개인정보 수집 유효기간 (0) | 2024.03.19 |
---|---|
[프로그래머스_Kotlin] 바탕화면 정리 (0) | 2024.03.18 |
[프로그래머스_Kotlin] 햄버거 만들기 (0) | 2024.03.12 |
[프로그래머스_Kotlin] 둘만의 암호 (0) | 2024.03.11 |
[프로그래머스_Kotlin] 대충 만든 자판 (1) | 2024.03.08 |