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 |
Tags
- 웹개발
- BOJ
- 필기후기
- 프로그래밍
- 후기
- java
- 공부
- 한국재정정보원
- 확인문제
- HTML
- 중소기업면접
- CSS
- 코딩
- 건보필기
- algorithm
- Linux
- 정수내림차순으로배치하기
- 인강
- 필기
- 부스트코스
- 프로그래머스
- 수박수박수박수박수?
- 이클립스
- 농은면접
- 프로그래밍언어
- 백준
- 웹프로그래밍
- 웹
- 연결요소의개수
- 알고리즘
Archives
- Today
- Total
공부하는 히욤이
[BOJ] 17413. 단어 뒤집기 2 본문
BaekJoon 17413. 단어 뒤집기 2
* 문제의 저작권은 BOJ 및 문제를 만든 사람에게 있습니다.
[문제 접근]
처음에는 Deque를 이용했는데 풀다보니 굳이 Deque를 안 써도 될 것 같아서 Stack을 사용했다.
boolean을 이용해서 여는 tag일 때는 stack에 있는걸 다 pop해줘서 반대로 출력되게 하고
tag 일 때는 글자를 그냥 출력하고 아닐 때는 stack에 담아서 < 일때 출력하거나 for문이 끝나고 전부 다 pop하게 했다.
[코드]
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Scanner;
import java.util.Stack;
public class Main_17413 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
Stack<Character> stack = new Stack<>();
String s = sc.nextLine();
boolean tag = false;
for (int i = 0; i < s.length(); i++) {
if (s.charAt(i) == '<') {
while (!stack.isEmpty()) {
System.out.print(stack.pop());
}
tag = true;
System.out.print(s.charAt(i));
} else if (s.charAt(i) == '>') {
tag = false;
System.out.print(s.charAt(i));
} else {
if (tag) {
System.out.print(s.charAt(i));
} else {
if (s.charAt(i) == ' ') {
while (!stack.isEmpty()) {
System.out.print(stack.pop());
}
System.out.print(" ");
} else {
stack.add(s.charAt(i));
}
}
}
}
while (!stack.isEmpty()) {
System.out.print(stack.pop());
}
}
}
'Algorithm > BaekJoon' 카테고리의 다른 글
[BOJ] 17298. 오큰수 (0) | 2020.02.10 |
---|---|
[BOJ] 10799. 쇠막대기 (0) | 2020.02.09 |
[BOJ] 10866. 덱 (0) | 2020.02.08 |
[BOJ] 1158. 요세푸스 문제 (0) | 2020.02.08 |
[BOJ] 10845. 큐 (0) | 2020.02.07 |