일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- ac 5430번
- 프로그래머스 자바
- HashMap
- 프로그래머스 java
- 백준 1806번 부분합 java
- append
- StringBuilder
- HashSet
- 코틀린기초
- 프로그래머스
- 백준 1043번 거짓말 - java 분리 집합
- mysql hy000 에러
- toUpperCase
- 백준 2473번 세 용액 - java
- 백준 1541
- map
- 백준 14938번 서강그라운드
- 백준 2467번 용액 자바 - 이분탐색
- Java
- replace()
- 백준 1197번 최소 스패닝 트리 - java
- Stack
- 백준 3190번
- kotlin
- hash
- 백준 1647번 도시 분할 계획 - java
- StringTokenizer
- dp
- 최소 힙 1927
- 18111번 마인크래프트 - java 구현
Archives
- Today
- Total
말하는 컴공감자의 텃밭
SW expert 1244번 최대 상금 - 자바 java DPS 본문
728x90
처음엔 쉬워 보였다, 최대자릿수가 6자리 기도 하고..
교환 횟수를 홀수와 짝수를 나누어서 큰수 찾아서 비교,,, 아 할게 많구나 싶었다.
아니면 그리디 방식으로 해야하나? 했다가 6자리니까 DPS로 풀어보자 했다.
DPS는 완전 탐색으로 자물쇠가 000부터 999까지라면 모든 수를 넣어서 열어보는 방식이다.
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 66 67 68 69 | import java.util.*; class Solution { public static int result; public static void main(String[] args) throws Exception { Scanner sc = new Scanner(System.in); int T; T = sc.nextInt(); for (int test_case = 1; test_case <= T; test_case++) { int number = sc.nextInt(); // 숫자 int cnt = sc.nextInt(); // 조작 횟수 int[] numbers = new int[6]; // 최대 길이는 6 int len = 0; while (number > 0) { // 숫자 배열로 옮겨주기 numbers[len++] = number % 10; number /= 10; } result = 0; if (len < cnt) // 조작횟수가 더 많다면 cnt = len; // 의미없으므로 줄여주기. dfs(cnt, 0, numbers, len); // dfs 함수 실행 // 3. Output System.out.printf("#%d %d%n", test_case, result); } } public static void dfs(int cnt, int start, int[] numbers, int len) { //Base case if (cnt == 0) { // 모든 조작을 완료했다면. int current = arrToInt(numbers, len); // 배열을 숫자로 if (current > result) { result = current; } return; } // 교환 for (int i = start; i < len - 1; ++i) { for (int j = i + 1; j < len; ++j) { swap(numbers, i, j); // 숫자 교환 dfs(cnt - 1, i, numbers, len); // 재귀호출로 반복 swap(numbers, i, j); // 다시 원래 위치로 } } } // 배열 다시 숫자로 변환. public static int arrToInt(int[] numbers, int len) { int result = 0; for (int i = len - 1; i >= 0; i--) { result = result * 10 + numbers[i]; } return result; } // 위치 바꾸는 함수 public static void swap(int[] arr, int i, int j) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } | cs |
에잉 귀차나
먼저 숫자를 %10으로 자릿수를 배열로 담아준다.
조작 횟수가 길이보다 많다면 의미가 없어지므로 불필요한 연산은 줄여주었고,
재귀 dfs 함수와, 위치를 바꾸는 swap 함수, 배열을 숫자로 만드는 함수 arrToInt를 만들어 주었다.
재귀는 사이클이 없도록 if문에 조작 횟수를 다 사용했을 경우 return 하도록 구성했다.
for문을 통해 모든 경우의 수를 찾는다.
조작 횟수 내에 모든 수를 바꾸기 위해 swap 함수로 숫자 위치를 교환해 준다.
DFS 함수내에 재귀함수로 조작 횟수(cnt-1)를 1 줄이고 반복한다.
이후 swap을 다시 실행하여 원래 위치로 돌려준다. -> 일반적인 재귀 방법
조작 횟수가 조건대로 다 사용했다면, 배열을 숫자로 바꾸고, result와 비교하여 더 크다면 값을 넣어준다.
결국 조작 횟수 내로 모든 경우의 수를 다 실행한 후, 최댓값을 찾아준다.
728x90
'알고리즘 > SW expert - Java' 카테고리의 다른 글
SW expert 1249. [S/W 문제해결 응용] 4일차 - 보급로 D4 - BFS (2) | 2023.12.04 |
---|---|
SW expert 5215번 햄버거 다이어트 D3 - DFS (0) | 2023.11.13 |
SW expert 17642. 최대 조작 횟수 <D3> - 자바 java (0) | 2023.08.12 |
Sw expert - 1208.Flatten <D3> - 자바 java (0) | 2023.08.06 |
SW Expert [S/W 문제해결 기본] 1일차 - View <D3> - 자바(java) (0) | 2023.07.08 |
Comments