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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main() {
string str;
cin >> str;
vector<string> vec;
int startIndex = 0; //숫자 시작 index 번호
int num1;
for (int i = 0; i < str.size(); i++) {
if (current == '-' || current == '+') {
vec.push_back(temp);
vec.push_back(string(1, current)); //연산자도 넣어 주기
startIndex = i + 1; //숫자는 연산자 다음부터 다시 시작
}
}
vec.pop_back(); //끝에 붙인 - 지워주기
//+ 먼저 다 하기
int i = 0;
while (true) {
if (vec[i] == "+") {
int temp = stoi(vec[i - 1]) + stoi(vec[i + 1]); //앞 숫자 + 뒷 숫자
vec[i - 1] = to_string(temp);
//두번 지웠으므로 i 증가 시켜줄 필요 없음. i는 이미 다음에 가리켜야할 인덱스 가리킴
}
else
i++;
if (i >= vec.size())
break;
}
//남은 - 연산 다 하기
bool isFirst = true;
int result;
for (int i = 0; i < vec.size(); i++) {
if (isFirst) {
result = stoi(vec[i]);
isFirst = false;
}
else if (vec[i] != "-") {
result = result - stoi(vec[i]);
}
}
cout << result;
return 0;
}
http://colorscripter.com/info#e" target="_blank" style="color:#e5e5e5text-decoration:none">Colored by Color Scripter
|
http://colorscripter.com/info#e" target="_blank" style="text-decoration:none;color:white">cs |
+ 연산 먼저 다 한 뒤, -는 순서대로 해주면 된다.
다 하고 생각해보니까 너무 어렵게 한거 같다
vec1에 넣어준 뒤, 숫자나 "+" 나오면 계속 더하고
"-" 만나면 지금 까지 더했던 값 다른 vec2에 push하고 지금까지 더했던 값 = 0 해주고
vec2에 값 사이에 - 연산 해주면 더 예쁘게 나올거같음
'Baekjoon' 카테고리의 다른 글
[#14501] 퇴사 (0) | 2020.03.13 |
---|---|
[#11052] 카드 구매하기 (0) | 2020.03.13 |
[#11399] ATM (0) | 2020.03.13 |
[#1931] 회의실 배정 (0) | 2020.03.13 |
[#11047] 동전 0 (0) | 2020.03.13 |