티스토리 뷰

💻JAVA 코드 바로보기

 

 

 

문제 설명

문자열 형태의 식을 계산하려 합니다. 식은 2개의 자연수와 1개의 연산자('+', '-', '*' 중 하나)로 이루어져 있습니다. 예를 들어 주어진 식이 "123+12"라면 이를 계산한 결과는 135입니다.

문자열로 이루어진 식을 계산하기 위해 다음과 같이 간단히 프로그램 구조를 작성했습니다.

1단계. 주어진 식에서 연산자의 위치를 찾습니다.
2단계. 연산자의 앞과 뒤에 있는 문자열을 각각 숫자로 변환합니다.
3단계. 주어진 연산자에 맞게 연산을 수행합니다.

문자열 형태의 식 expression이 매개변수로 주어질 때, 식을 계산한 결과를 return 하도록 solution 메소드를 작성하려 합니다. 위 구조를 참고하여 코드가 올바르게 동작할 수 있도록 빈칸에 주어진 func_a, func_b, func_c 메소드와 매개변수를 알맞게 채워주세요.


매개변수 설명

문자열 형태의 식 expression이 solution 메소드의 매개변수로 주어집니다.

  • expression은 연산자 1개와 숫자 2개가 결합한 형태입니다.
  • 연산자는 '+', '-', '*'만 사용됩니다.
  • 숫자는 1 이상 10,000 이하의 자연수입니다.

return 값 설명

expression을 계산한 결과를 return 해주세요.

  • 계산 결과는 문자열로 변환하지 않아도 됩니다.

예시

expression return
"123+12" 135

예시 설명

'+'를 기준으로 앞의 숫자는 123이고 뒤의 숫자는 12이므로 두 숫자를 더하면 135가 됩니다.

 

 

 

 

 

 

 

주어진 코드

class Solution {
    class Pair{
        public int firstNum;
        public int secondNum;
    }

    public int func_a(int numA, int numB, char exp){
        if (exp == '+')
            return numA + numB;
        else if (exp == '-')
            return numA - numB;
        else
            return numA * numB;
    }

    public int func_b(String exp){
        for(int i = 0; i < exp.length(); i++){
            char e = exp.charAt(i);
            if(e == '+' || e == '-' || e == '*')
                return i;
        }
        return -1;
    }
    public Pair func_c(String exp, int idx){
        Pair ret = new Pair();
        ret.firstNum = Integer.parseInt(exp.substring(0, idx));
        ret.secondNum = Integer.parseInt(exp.substring(idx + 1));
        return ret;
    }

    public int solution(String expression) {
        int expIndex = func_@@@(@@@);
        Pair numbers = func_@@@(@@@);
        int result = func_@@@(@@@);
        return result;
    }

    // The following is main method to output testcase.
    public static void main(String[] args) {
        Solution sol = new Solution();
        String expression = "123+12";
        int ret = sol.solution(expression);

        // Press Run button to receive output.
        System.out.println("Solution: return value of the method is " + ret + " .");
    }
}

 

 

 

 

 

코드 분석

// 연산자 앞/뒤 숫자
class Pair{
    public int firstNum;
    public int secondNum;
}
//연산자에 맞춰 계산된 결과를 반환
public int func_a(int numA, int numB, char exp){
    if (exp == '+')
        return numA + numB;
    else if (exp == '-')
        return numA - numB;
    else
        return numA * numB;
}
//연산자의 위치를 반환
public int func_b(String exp){
    for(int i = 0; i < exp.length(); i++){
        char e = exp.charAt(i);
        if(e == '+' || e == '-' || e == '*')
            return i;
    }
    return -1;
}
//연산자의 위치를 기준으로 앞숫자와 뒷숫자를 각각 구함 (string -> int)
public Pair func_c(String exp, int idx){
    Pair ret = new Pair();
    ret.firstNum = Integer.parseInt(exp.substring(0, idx));
    ret.secondNum = Integer.parseInt(exp.substring(idx + 1));
    return ret;
}

 

각 함수의 기능을 필요한 순서대로 나열해보면, 다음과 같다.

연산자의 위치 반환 -> 위치를 기준으로 앞/뒤 숫자 저장 -> 계산 

즉 func_b -> func_c -> func_a 순으로 호출한다.

 

//계산 결과 반환
public int solution(String expression) {
    int expIndex = func_@@@(@@@);
    Pair numbers = func_@@@(@@@);
    int result = func_@@@(@@@);
    return result;
}
//계산 결과 반환
public int solution(String expression) {
    int expIndex = func_b(expression);
    Pair numbers = func_c(expression,expIndex);
    int result = func_a(numbers.firstNum,numbers.secondNum,expression.charAt(expIndex));
    return result;
}

 

 

 

 

정답 코드(YBM과 동일)

class Solution {
    // 연산자 앞/뒤 숫자
    class Pair{
        public int firstNum;
        public int secondNum;
    }

    //연산자에 맞춰 계산된 결과를 반환
    public int func_a(int numA, int numB, char exp){
        if (exp == '+')
            return numA + numB;
        else if (exp == '-')
            return numA - numB;
        else
            return numA * numB;
    }

    //연산자의 위치를 반환
    public int func_b(String exp){
        for(int i = 0; i < exp.length(); i++){
            char e = exp.charAt(i);
            if(e == '+' || e == '-' || e == '*')
                return i;
        }
        return -1;
    }

    //연산자의 위치를 기준으로 앞숫자와 뒷숫자를 각각 구함 (string -> int)
    public Pair func_c(String exp, int idx){
        Pair ret = new Pair();
        ret.firstNum = Integer.parseInt(exp.substring(0, idx));
        ret.secondNum = Integer.parseInt(exp.substring(idx + 1));
        return ret;
    }

    //계산 결과 반환
    public int solution(String expression) {
        int expIndex = func_b(expression);
        Pair numbers = func_c(expression,expIndex);
        int result = func_a(numbers.firstNum,numbers.secondNum,expression.charAt(expIndex));
        return result;
    }

    // The following is main method to output testcase.
    public static void main(String[] args) {
        Solution sol = new Solution();
        String expression = "123+12";
        int ret = sol.solution(expression);

        // Press Run button to receive output.
        System.out.println("Solution: return value of the method is " + ret + " .");
    }
}

 

 

 

 

실행 결과

댓글