문제 설명
my_string은 "3 + 5"처럼 문자열로 된 수식입니다. 문자열 my_string이 매개변수로 주어질 때, 수식을 계산한 값을 return 하는 solution 함수를 완성해주세요
제한사항
- 연산자는 +, -만 존재합니다.
- 문자열의 시작과 끝에는 공백이 없습니다.
- 0으로 시작하는 숫자는 주어지지 않습니다.
- 잘못된 수식은 주어지지 않습니다.
- 5 ≤ my_string의 길이 ≤ 100
- my_string을 계산한 결과값은 1 이상 100,000 이하입니다.
- my_string의 중간 계산 값은 -100,000 이상 100,000 이하입니다.
계산에 사용하는 숫자는 1 이상 20,000 이하인 자연수입니다. - my_string에는 연산자가 적어도 하나 포함되어 있습니다
- my_string의 중간 계산 값은 -100,000 이상 100,000 이하입니다.
- return type 은 정수형입니다.
- my_string의 숫자와 연산자는 공백 하나로 구분되어 있습니다.
import java.util.*;
class Solution {
public int solution(String my_string) {
int answer = 0;
String[] s = my_string.split(" ");
answer += Integer.parseInt(s[0]);
for(int i =1; i< s.length-1; i++){
if(s[i].equals("+")){
answer += Integer.parseInt(s[i+1]);
}
if(s[i].equals("-")){
answer -= Integer.parseInt(s[i+1]);
}
}
return answer;
}
}
1. 문자열을 공백을 기준으로 split() 함수를 이용해 배열 s에게 넣는다.
2. answer에 분리한 문자열 배열 s의 첫 번째 원소를 정수로 변환하여 answer에 더한다.
3. 배열 S을 순환하여 + 를 만나면 + 다음 배열을 원소를 정수로 변환하여 answer더한다
3. 배열 S을 순환하여 -를 만나면 - 다음 배열을 원소를 정수로 변환하여 answer뺀다.
'알고리즘 문제 > 프로그래머스' 카테고리의 다른 글
프로그래머스 0단계 문자열 정렬하기 (2) - java (0) | 2023.05.11 |
---|---|
프로그래머스 0단계 문자열안에 문자열- java (0) | 2023.05.11 |
프로그래머스 0 단계 자릿수 더하기-java (0) | 2023.05.10 |
프로그래머스 0 단계 n의 배수 고르기-java (0) | 2023.05.10 |
프로그래머스 0 단계 숫자 찾기-java (0) | 2023.05.10 |