Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- genarics
- 자바
- remembercoroutinescope
- 명령형ui
- JCF
- 양과 늑대
- 안드로이드
- 2022 KAKAO BLIND RECRUITMENT
- viewbinding
- 2989번
- derivedstateof
- ModalBottomSheet
- 2022 kakao blind
- 뷰바인딩
- compose
- 선언형 ui
- BottomSheet
- snapshotflow
- 선언형ui
- producestate
- mutableStateOf
- mutablestate
- clean coder
- bottomscaffold
- State
- 명령형 ui
- 클린아키텍처
- rememberupdatedstate
- Java
- apollo3
Archives
- Today
- Total
버미
프로그래머스 - 문자열 계산하기 본문
문제 설명
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
의 숫자와 연산자는 공백 하나로 구분되어 있습니다.
문제풀이
#include <string>
#include <vector>
#include <algorithm>
#include <sstream>
using namespace std;
int solution(string my_string) {
int answer = 0;
vector<string> str;
istringstream sstr(my_string);
string buffer;
while (getline(sstr, buffer, ' ')) {
str.push_back(buffer);
}
answer += stoi(str[0]);
for (int i = 1; i < str.size();i++) {
if (str[i] == "+") {
answer += stoi(str[i + 1]);
}
else if (str[i] == "-") {
answer -= stoi(str[i + 1]);
}
}
return answer;
}
C언어로 하다가 계속 엑세스 위반이 나서 JAVA나 C++중에 친숙한 언어로 풀었다.
'코딩 트레이닝' 카테고리의 다른 글
백준 2563번 - 색종이(c언어) (0) | 2023.07.07 |
---|---|
백준 10844번 - 쉬운 계단 수(C언어) (0) | 2023.07.06 |
프로그래머스 3진법 뒤집기 (0) | 2023.07.05 |
백준 1157번 - 단어 공부 (0) | 2023.07.04 |
프로그래머스 qr code (0) | 2023.07.02 |