반응형

@notepad_jj2

츄르사려고 코딩하는 코집사입니다.


1. [프로그래머스] OX퀴즈 자바(JAVA)

1) 문제 제목 : OX퀴즈

 

2) 문제 출처

https://school.programmers.co.kr/learn/courses/30/lessons/120907

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

2. 문제

덧셈, 뺄셈 수식들이 'X [연산자] Y = Z' 형태로 들어있는 문자열 배열 quiz가 매개변수로 주어집니다. 수식이 옳다면 "O"를 틀리다면 "X"를 순서대로 담은 배열을 return하도록 solution 함수를 완성해주세요.

 

3. 제약사항

  • 연산 기호와 숫자 사이는 항상 하나의 공백이 존재합니다. 단 음수를 표시하는 마이너스 기호와 숫자 사이에는 공백이 존재하지 않습니다.
  • 1 ≤ quiz의 길이 ≤ 10
  • X, Y, Z는 각각 0부터 9까지 숫자로 이루어진 정수를 의미하며, 각 숫자의 맨 앞에 마이너스 기호가 하나 있을 수 있고 이는 음수를 의미합니다.
  • X, Y, Z는 0을 제외하고는 0으로 시작하지 않습니다.
  • -10,000 ≤ X, Y ≤ 10,000
  • -20,000 ≤ Z ≤ 20,000
  • [연산자]는 + 와 - 중 하나입니다.

 

4. 입출력

quizresult

["3 - 4 = -3", "5 + 6 = 11"] ["X", "O"]
["19 - 6 = 13", "5 + 66 = 71", "5 - 15 = 63", "3 - 1 = 2"] ["O", "O", "X", "O"]

입출력 예 설명

입출력 예 #1

  • 3 - 4 = -3 은 틀린 수식이므로 "X", 5 + 6 = 11 은 옳은 수식이므로 "O" 입니다. 따라서 ["X", "O"]를 return합니다.

입출력 예 #2

  • 19 - 6 = 13 은 옳은 수식이므로 "O", 5 + 66 = 71 은 옳은 수식이므로 "O", 5 - 15 = 63 은 틀린 수식이므로 "X", 3 - 1 = 2는 옳은 수식이므로 "O" 따라서 ["O", "O", "X", "O"]를 return합니다.

 

5. 풀이

- 문자열 계산하기 문제와 정망 비슷한 문제다.

- split 함수로 띄어쓰기를 기준으로 분리하여 배열에 넣은 다음, 0, 2, 4번째 숫자를 계산하는 문제다.

2022.11.08 - [알고리즘/프로그래머스] - [프로그래머스] 문자열 계산하기 자바(JAVA)

 

[프로그래머스] 문자열 계산하기 자바(JAVA)

츄르사려고 코딩하는 코집사입니다. 1. [프로그래머스] 문자열 계산하기 자바(JAVA) 1) 문제 제목 : 문자열 계산하기 2) 문제 출처 https://school.programmers.co.kr/learn/courses/30/lessons/120902 프로그래머스 코

yongku.tistory.com

 

6. 소스 코드

class Solution {
    public String[] solution(String[] quiz) {
        String[] answer = new String[quiz.length];
        
        for(int i = 0; i < quiz.length; i++) {
            String[] stringArr = quiz[i].split(" ");
            
            int num1 = Integer.parseInt(stringArr[0]);
            int num2 = Integer.parseInt(stringArr[2]);
            int num3 = Integer.parseInt(stringArr[4]); // 정답
            
            if(stringArr[1].equals("+")) {
                if((num1 + num2) == num3) {
                    answer[i] = "O";
                } else {
                    answer[i] = "X";
                }
            } 
            
            if(stringArr[1].equals("-")) {
                if((num1 - num2) == num3) {
                    answer[i] = "O";
                } else {
                    answer[i] = "X";
                }
            }
        }
        return answer;
    }
}

반응형
  • 네이버 블러그 공유하기
  • 네이버 밴드에 공유하기
  • 페이스북 공유하기
  • 카카오스토리 공유하기