<코딩 테스트>
[문제 설명]
덧셈, 뺄셈 수식들이 '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
[연산자]는 + 와 - 중 하나입니다.
<나의 풀이 과정>
처음에는 " "으로 split 하지 않고 그냥 풀었었는데 생각해보니 9이상의 숫자들은
계산이 되지 않았습니다 ㅎㅎ.. 그래서 split으로 우선 숫자들을 나눠준 뒤, +와-가 [1] 번째 자리에 있으니,
+인지 -인지를 파악한 뒤, 각각 다르게 연산하여 answer에 답을 넣었습니다.
다음에는 맵으로도 풀어보고 싶은 문제라서 아래 다른사람 코드에 적어놓았습니다.
<나의 풀이 코드>
package com.programmers.level00.OX퀴즈;
//덧셈, 뺄셈 수식들이 'X [연산자] Y = Z' 형태로 들어있는 문자열 배열 quiz가 매개변수로 주어집니다.
//수식이 옳다면 "O"를 틀리다면 "X"를 순서대로 담은 배열을 return하도록 solution 함수를 완성해주세요.
public class Test {
public static void main(String[] args) {
System.out.println(solution(new String[] { "3 - 4 = -3", "5 + 6 = 11" })); // ["X", "O"]
System.out.println(solution(new String[] { "19 - 6 = 13", "5 + 66 = 71", "5 - 15 = 63", "3 - 1 = 2" })); // ["O", "O", "X", "O"]
}
static String[] solution(String[] quiz) {
String[] answer = new String[quiz.length];
String[] temp = new String[quiz.length];
// 숫자 10이상인 수가 있을 수 있으니, " "으로 나눠서 문자열에 저장
for (int i = 0; i < quiz.length; i++) {
temp = quiz[i].split(" ");
// 마이너스 일때
if(temp[1].equals("-")) {
if(Integer.parseInt(temp[0])-Integer.parseInt(temp[2])==Integer.parseInt(temp[4])) {
answer[i]="O";
}
else {
answer[i]="X";
}
}
if(temp[1].equals("+")) {
if(Integer.parseInt(temp[0])+Integer.parseInt(temp[2])==Integer.parseInt(temp[4])) {
answer[i]="O";
}else {
answer[i]="X";
}
}
}
for (String string : answer) {
System.out.println(string);
}
return answer;
}
}
<다른 사람 풀이>
class Solution {
public String[] solution(String[] quiz) {
for(int i=0; i<quiz.length; i++){
String[] text = quiz[i].split(" ");
int result = Integer.parseInt(text[0]) + ( Integer.parseInt(text[2]) * ( text[1].equals("+") ? 1:-1) );
quiz[i] = result == Integer.parseInt(text[4])? "O": "X";
}
return quiz;
}
}
<다른 사람 풀이>
import java.util.Arrays;
class Solution {
public String[] solution(String[] quiz) {
return Arrays.stream(quiz)
.map(it -> it.trim().split(" ")).map(it -> {
if ("+".equals(it[1]))
return Integer.parseInt(it[0]) + Integer.parseInt(it[2]) == Integer.parseInt(it[4]) ? "O" : "X";
else
return Integer.parseInt(it[0]) - Integer.parseInt(it[2]) == Integer.parseInt(it[4]) ? "O" : "X";
}
).toArray(String[]::new);
}
}
https://school.programmers.co.kr/learn/courses/30/lessons/120913
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
'주니어 기초 코딩공부 > JAVA_programmers_코딩테스트' 카테고리의 다른 글
다음에 올 숫자_programmers_lev00 (0) | 2023.01.01 |
---|---|
최빈값 구하기_programmers_lev00 (0) | 2023.01.01 |
직사각형 넓이 구하기_programmers_lev00 (0) | 2022.12.29 |
삼각형의 완성조건 (2)_programmers_lev00 (0) | 2022.12.29 |
소인수분해_programmers_lev00 (0) | 2022.12.28 |