풀이 방법
보물 상자에 적힌 숫자로 만들 수 있는 모든 수 중 K번째로 큰 수를 10진수로 만들어 출력하는 문제였습니다.
1. 각 변에는 동일한 개수의 숫자가 있다.
2. 시계 방향으로 회전한다.
3. 크기 순서를 셀 때 중복된 수는 세지 않는다.
이를 바탕으로
동일한 길이의 비밀번호를 만들기 위해
1. 숫자의 길이인 N을 4로 나누어 각 변에 숫자가 몇 개씩 들어가야 하는지 확인
2. list에 각 숫자 담기
3. N/4개씩 끊어 result에 담기
4. 시계 방향으로 회전하기 때문에 list맨뒤에 있는 값 맨 앞으로 넣어주기
위의 2 ~ 4번 N/4번 반복해준 뒤,
result에 담긴 값 내림차순으로 정렬해 K번째의 수를 10진수로 변환 한 뒤 출력해주었습니다.
코드
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
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.StringTokenizer;
public class Solution_5658_보물상자비밀번호 {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringBuilder sb = new StringBuilder();
StringBuilder answer = new StringBuilder();
StringTokenizer st;
List<Character> list = new ArrayList<>();
List<String> result = new ArrayList<>();
int T = Integer.parseInt(br.readLine());
for(int tc=1;tc<=T;tc++) {
st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken())/4; //숫자개수
int K = Integer.parseInt(st.nextToken()); //k번째수
String num = br.readLine();
for(int i=0;i<num.length();i++) list.add(num.charAt(i));
for(int i=0;i<N;i++) {
int count=0;
for(int j=0;j<num.length();j++) {
sb.append(list.get(j));
count++;
if(count==N) {
if(!result.contains(sb.toString())) {
result.add(sb.toString());
}
sb.setLength(0);
count=0;
}
}
char c = list.remove(list.size()-1);
list.add(0,c);
}
Collections.sort(result, Collections.reverseOrder());
for(int i=0;i<result.size();i++) {
if(i==K-1) {
answer.append("#"+tc+" "+Integer.parseInt(result.get(i),16)+"\n");
break;
}
}
list.clear();
result.clear();
}
System.out.println(answer.toString());
}
}
|
cs |
'문제 > SWEA' 카테고리의 다른 글
[SWEA 1210] Ladder1 (JAVA) (0) | 2021.09.16 |
---|---|
[SWEA 1227] 미로2 (JAVA) (0) | 2021.03.16 |
[SWEA 4012] 요리사 (JAVA) (1) | 2021.03.16 |