🎁 문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/120902
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
🎁 문제 설명
- 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에는 연산자가 적어도 하나 포함되어 있습니다. return type 은 정수형입니다. my_string의 숫자와 연산자는 공백 하나로 구분되어 있습니다.
🎁 입출력 예시
my_string | result |
"3 + 4" | 7 |
🎁 코드
class Solution {
public int solution(String my_string) {
String[] S = my_string.split(" ");
int answer = Integer.parseInt(S[0]);
for (int i = 1; i < S.length - 1; i++) {
if(S[i].equals("+")){
answer += Integer.parseInt(S[i + 1]);
} else if(S[i].equals("-")){
answer -= Integer.parseInt(S[i + 1]);
}
}
return answer;
}
}
🎁 코드 설명
1) my_string의 문자를 split() 함수를 이용해서 공백을 제외하고 인덱스 배열의 갯수를 받는다.
2) 비교를 위해서 S[0] 인덱스를 answer에 대입
3) 수식이 1개 밖에 없기 때문에 계산은 한 번만 진행한다고 판단한다.
4) 1번 인덱스가 '+' /'-' 인지 확인해서 다음 인덱스의 Value가 몇인지 파악하여 값의 수식을 진행한다.
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 문자열 다루기 기본 [Java] (0) | 2023.08.26 |
---|---|
[프로그래머스] 외계행성의 나이 [Java] (1) | 2023.08.24 |
[프로그래머스] 최대공약수와 최소공배수 [Java] (0) | 2023.08.23 |
댓글