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
- parseInt()
- 순열코드
- 자바 재귀 조합
- Interface
- 자바 순열 코드
- 서로소
- java Collections.sort()
- 알고리즘 그래프
- 자바 조합 재귀
- Java
- 재귀함수
- 순열 재귀
- char to str
- 상속
- 조합 재귀
- 알고리즘
- jquery 이벤트 처리
- 자바스크립트 이벤트중지
- jquery dom 계층 선택자
- jquery 필터선택자
- 자바
- java lambda
- 재귀
- inner class
- jquery 속성선택자
- 자바입출력
- java 내부 클래스
- str to char array
- 자바스크립트 이벤트처리
- 후위표기
Archives
- Today
- Total
유블로그
[Java] BOJ 1541 잃어버린 괄호 본문
[Java] BOJ 1541 잃어버린 괄호
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
public class BOJ_1541_잃어버린괄호 {
static String str;
static List<String> list;
public static void main(String[] args) throws Exception {
input();
int SUM = Integer.parseInt(list.get(0));
int i = 1;
out:while(true) {
if(i >= list.size()) break;
char oper = list.get(i).charAt(0);
if (oper == '-') {
int sum = Integer.parseInt(list.get(i + 1));
int idx = i+2;
while(true) {
if(idx >= list.size()) {
SUM -= sum;
break out;
}
if(list.get(idx).charAt(0) != '+') break;
if(list.get(idx).charAt(0) == '+') {
sum += Integer.parseInt(list.get(idx+1));
idx+=2;
}
}
SUM -= sum;
i = idx;
} else {
SUM += Integer.parseInt(list.get(i + 1));
i+=2;
}
}
System.out.println(SUM);
} // main
static void input() throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
str = br.readLine();
list = new ArrayList<>();
String s = "";
for (int i = 0; i < str.length(); i++) {
if (Character.isDigit(str.charAt(i))) {
s += str.charAt(i);
} else {
list.add(s);
s = "";
list.add(Character.toString(str.charAt(i)));
}
}
if (s.length() > 0)
list.add(s);
}
}
실버 2인데... 문제를 잘못 접근해서 엄청 오래 풀었다.
괄호 내에 숫자가 두 개만 들어간다고 생각하고 풀었었다 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ
그게 아니라는 걸 깨닫고 나서는... 수식을 몇 개 적어보다가
- 가 나왔으면 그 뒤 +는 다 괄호로 묶어 다 더하고 다시 - 가 나왔을 때 앞에 더했던 걸 빼주면 되겠다 싶어서
입력을 부호와 숫자 List 로 넣어주고 while 문으로 순회하는데 - 가 나왔다면 + 가 그만 나올 때까지 또 while문 순회하면서 쭉 더하고, - 가 다시 나오면 sum 에 합한 걸 빼는 식으로 2중 while로 했다.
그런데 다른 사람들 풀이를 보니 매우 똑똑하게 풀었더라..
입력을 먼저 - 로 split 하고
뭉텅이들을 + 로 또 split해서 더한 덩어리들을
쭉 마이너스 하는 식... wow
어쩜 저런 생각을 하지 멋지다
'알고리즘' 카테고리의 다른 글
[Java] BOJ 4949 균형 잡힌 세상 백준 (0) | 2021.05.03 |
---|---|
[Java] BOJ 5430 AC 백준 (0) | 2021.05.02 |
[Java] BOJ 2212 센서 (0) | 2021.04.28 |
[Java] BOJ 2470 두 용액 (0) | 2021.04.26 |
[Java] BOJ 19237 어른상어 (0) | 2021.04.25 |