주니어 기초 코딩공부/JAVA_programmers_코딩테스트

OX퀴즈_programmers_lev00

jju_developer 2023. 1. 1. 12:23
728x90

<코딩 테스트>

[문제 설명]
덧셈, 뺄셈 수식들이 '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

 

728x90