풀이 방법
- 문자열 S의 가장 앞의 문자 하나를 문자열 T의 마지막에 추가
- 문자열 S의 가장 뒤의 문자 하나를 문자열 T의 마지막에 추가
문자열 T들 중 사전으로 가장 빠른 문자열을 출력하는 문제였습니다.
코드
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
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
public class Main_BJ_6137_문자열생성 {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
ArrayList<Character> result = new ArrayList<>();
StringBuilder sb = new StringBuilder();
int N = Integer.parseInt(br.readLine());
char [] alpabet = new char[N];
for(int i=0;i<N;i++) {
String word = br.readLine();
alpabet[i] = word.charAt(0);
}
int start=0, end=N-1;
while(start<=end) {
if((int)alpabet[start]<(int)alpabet[end]) {
result.add(alpabet[start++]);
}else if((int)alpabet[start]==(int)alpabet[end]) {
int front = start, back=end;
boolean check = true;
while(alpabet[front]==alpabet[back]) {
if(back>0) back--;
if(front<N-1) front++;
if((int)alpabet[front]<(int)alpabet[back]) check=true;
else if((int)alpabet[front]>(int)alpabet[back]) check=false;
}
if(check) result.add(alpabet[start++]);
else result.add(alpabet[end--]);
}else {
result.add(alpabet[end--]);
}
}
for(int i=0;i<result.size();i++) {
if(i!=0 && i%80==0) sb.append("\n");
sb.append(result.get(i));
}
System.out.println(sb.toString());
}
}
|
cs |
'문제 > 백준' 카테고리의 다른 글
백준 23056번 참가자 명단 [JAVA] (0) | 2021.10.17 |
---|---|
백준 8911번 거북이 [JAVA] (0) | 2021.10.13 |
백준 16562 친구비 [JAVA] (0) | 2021.09.21 |
백준 2531번 회전 초밥 [JAVA] (0) | 2021.09.17 |
백준 1520 내리막길 [JAVA] (0) | 2021.09.10 |