본문 바로가기

알고리즘/백준

[백준] 11066 파일 합치기

문제링크: gaegosoo.tistory.com/manage/newpost/?type=post&returnURL=%2Fmanage%2Fposts%2F

 

TISTORY

나를 표현하는 블로그를 만들어보세요.

www.tistory.com

문제를 풀 때 항상 완전탐색을 먼저 고려해본다. 부분 문제로 나눌 수 있는게 직관적으로 보여서 그렇게 풀었다.

리턴이 많아서 깔끔해 보이진 않지만 예외 없이 한번에 통과하는 코드를 짜고자 할때 나오는 습관이다.

 

import java.io.*;
import java.util.*;

public class Main {
	public static int N;
	public static int []arr;
	public static int[][] dp;
	public static final int MAX = 987654321;
	public static int dfs(int left,int right){
		if(dp[left][right] !=-1){
			return dp[left][right];
		}
		if(left+1==right){
			return dp[left][right] = arr[left]+arr[right];
		}
		if(left==right){
			return dp[left][right]=0;
		}
		dp[left][right] = MAX;
		int sum =0;
		for(int i=left;i<=right;i++){
			sum+= arr[i];
		}
		for(int i=left;i<right;i++){
			dp[left][right] = Math.min(dfs(left,i)+dfs(i+1,right)+sum, dp[left][right]);
		}
		return dp[left][right];
	}

	public static void main(String[] args) throws Exception{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		int tc = Integer.parseInt(br.readLine());
		while(tc--!=0){
			N = Integer.parseInt(br.readLine());
			arr = new int[N+1];
			dp = new int[N+1][N+1];
			for(int i=0;i<N;i++){
				for(int j=0;j<N;j++){
					dp[i][j] = -1;
				}
			}
			StringTokenizer st = new StringTokenizer(br.readLine());
			for(int i=0;i<N;i++){
				arr[i] = Integer.parseInt(st.nextToken());
			}
			
			System.out.println(dfs(0,N-1));
		}
		
	}


}

'알고리즘 > 백준' 카테고리의 다른 글

[백준] 15681 트리와 쿼리  (0) 2020.12.29
[백준] 7579 앱  (0) 2020.12.29
[백준] 1956 운동  (0) 2020.12.23
[백준] 1504 특정한 최단 경로  (0) 2020.12.23
[백준] 11286 절대값 힙  (0) 2020.12.23