반응형
문제 설명
덧셈, 뺄셈 수식들이 'X [연산자] Y = Z' 형태로 들어있는 문자열 배열 quiz가 매개변수로 주어집니다.
수식이 옳다면 "O"를 틀리다면 "X"를 순서대로 담은 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 연산 기호와 숫자 사이는 항상 하나의 공백이 존재합니다. 단 음수를 표시하는 마이너스 기호와 숫자 사이에는 공백이 존재하지 않습니다.
- 1 ≤ quiz의 길이 ≤ 10
- X, Y, Z는 각각 0부터 9까지 숫자로 이루어진 정수를 의미하며, 각 숫자의 맨 앞에 마이너스 기호가 하나 있을 수 있고 이는 음수를 의미합니다.
- X, Y, Z는 0을 제외하고는 0으로 시작하지 않습니다.
- -10,000 ≤ X, Y ≤ 10,000
- -20,000 ≤ Z ≤ 20,000
- [연산자]는 + 와 - 중 하나입니다.
입출력 예
입출력 예 #1
Input : ["3 - 4 = -3", "5 + 6 = 11"] / Output : ["X", "O"]
더보기
3 - 4 = -3 은 틀린 수식이므로 "X", 5 + 6 = 11 은 옳은 수식이므로 "O" 입니다. 따라서 ["X", "O"]를 return합니다.
입출력 예 #2
Input : ["19 - 6 = 13", "5 + 66 = 71", "5 - 15 = 63", "3 - 1 = 2"] / Output : ["O", "O", "X", "O"]
더보기
19 - 6 = 13 은 옳은 수식이므로 "O", 5 + 66 = 71 은 옳은 수식이므로 "O", 5 - 15 = 63 은 틀린 수식이므로 "X", 3 - 1 = 2는 옳은 수식이므로 "O" 따라서 ["O", "O", "X", "O"]를 return합니다.
제출코드
import java.util.Arrays;
class Solution {
public String[] solution(String[] quiz) {
return Arrays.stream(quiz)
.map(q -> {
String[] qa = q.split(" ");
int num1 = Integer.parseInt(qa[0]);
String operator = qa[1];
int num2 = Integer.parseInt(qa[2]);
int resultNum = Integer.parseInt(qa[4]);
boolean result = operator.equals("+") ?
(num1 + num2) == resultNum :
(num1 - num2) == resultNum;
return result ? "O" : "X";
}).toArray(String[]::new);
}
}
- quiz를 stream화 합니다.
- split로 문자열을 배열로 나누어 연산할 숫자, 연산자, 결과값을 추출합니다.
- 실제 연산과 결과값이 일치할때 O, 일치하지 않을때 X를 반환하여 다시 Array로 변환해 반환합니다.
출처 : https://school.programmers.co.kr/learn/courses/30/lessons/120907
반응형
'코딩테스트' 카테고리의 다른 글
코테 Lv0 - 특이한 정렬 (0) | 2024.11.11 |
---|---|
코테 Lv0 - 다항식 더하기 (2) | 2024.11.10 |
코테 Lv0 - 다음에 올 숫자 (0) | 2024.11.09 |
코테 Lv0 - 최빈값 구하기 (0) | 2024.11.08 |
코테 Lv0 - 연속된 수의 합 (1) | 2024.11.08 |