| 문제 설명 ❓
덧셈, 뺄셈 수식들이 '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
- [연산자]는 + 와 - 중 하나입니다.
| 입출력 예 💬
quiz | result |
["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 합니다.
| 풀이 🔥
⚠️ 한 번씩 읽어주세요 ⚠️
제 개인의 풀이 방법이며 틀린 풀이 방법 일수도, 더 나은 풀이법이 존재할 수도 있습니다!
전체 코드는 깃헙 링크 혹은 하단 접은 글을 펼쳐 확인가능하며, 복붙이 아닌 참고용 코드입니다
이번 문제는 처음 시도했을 때 테스트 케이스에서는 통과, 제출을 했을 때는 런타임 에러가 걸렸었던 문제였습니다.
- 1번째 방법 : 단순히 공백을 없애고, '+', '=' 기호의 인덱스를 구하고 문자열을 잘라서 연산자의 왼쪽 값, 오른쪽 값, 결과 값을 구한 후 얻은 결과 값과 왼쪽, 오른쪽값을 더한 결과를 비교하는 방식으로 진행했었습니다.
=> 각 숫자 앞에 '-' 기호가 붙을 수도 있다는 것을 체크하지 못하여 연산자 인덱스를 구할 때 엉뚱한 인덱스를 구하는 것이 문제였습니다.
=> 코드가 의외로 길어집니다. - 2번째 방법 (통과) : 처음에 데이터 문자열을 보았을 때 공백으로 나뉜 것을 보고 1번째 방법처럼 인덱스를 구하는 것이 아닌 수식의 형태는 정해져 있으므로, 공백을 기준으로 문자열을 나누는 방식을 사용했습니다. 나뉜 문자열의 인덱스는 각각의 역할이 정해져 있으므로 훨씬 쉽게 가공할 수 있습니다. 체크하는 방식은 1번째 방법과 동일합니다.
[깃헙 / Github]
😻 댓글과 공감 한 번씩 감사드립니다 😻
| 전체 코드 🔎
더보기
using System;
public class Solution {
public string[] solution(string[] quiz) {
string[] answer = new string[quiz.Length];
for(int i = 0; i < quiz.Length; i++)
{
answer[i] = CheckCorrectOperation(quiz[i]) ? "O" : "X";
}
return answer;
}
// 올바른 수식인지 판단하는 함수.
public bool CheckCorrectOperation(string str)
{
// 공백을 기준을 str을 자름.
string[] elements = str.Split(" ");;
// elements[0] -> 연산자의 왼쪽 값
int leftVal = int.Parse(elements[0]);
// elements[2] -> 연산자의 오른쪽 값
int rightVal = int.Parse(elements[2]);
// elements[4] -> str의 결과 값
int resultVal = int.Parse(elements[4]);
// str의 결과값과 실제 leftVal, rightVal값을 실제 연산하여 비교 진행
return resultVal == ((elements[1] == "+") ? leftVal + rightVal : leftVal - rightVal);
}
}