슈콩

[SWEA] 2일차 - 최대상금 본문

Algorithms/SWEA

[SWEA] 2일차 - 최대상금

shukong 2025. 10. 30. 14:33

 

 

 

[문제]

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV15Khn6AN0CFAYD

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

 

 

 

[소스 코드]

import java.util.*;
import java.io.*;
public class Solution {
	static int max,result = 0;
	static char[] nums;
	public static void main(String[] args) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		int T = Integer.parseInt(br.readLine());
		for(int tc=1;tc<=T;tc++) {
			st = new StringTokenizer(br.readLine());
			String num = st.nextToken();
			nums = new char[num.length()];
			for(int i=0;i<num.length();i++) {
				nums[i] = num.charAt(i);
			}
			max = Integer.parseInt(st.nextToken());
			result = 0;
			dfs(0,0);
			System.out.println("#"+tc+" "+result);
		}
	}
	private static void dfs(int idx,int cnt) {
		if(cnt==max) {
			int number = Integer.valueOf(new String(nums));
			result = Math.max(result, number);
			return;
		}
		for(int i=idx;i<nums.length;i++) {
			for(int j=i+1;j<nums.length;j++) {
				swap(i,j);
				dfs(i,cnt+1);
				swap(j,i);
			}
		}
	}
	private static void swap(int i,int j) {
		char temp = nums[i];
		nums[i] = nums[j];
		nums[j] = temp;
	}
}

'Algorithms > SWEA' 카테고리의 다른 글

[SWEA] 농작물 수확하기  (0) 2025.11.03
[SWEA] N-Queen  (0) 2025.10.30
[SWEA] 1일차 - Flattern  (0) 2025.10.30
[SWEA] 햄버거 다이어트  (0) 2025.10.30
[SWEA] 1일차 - VIEW  (0) 2025.10.30