Dalyoung 2021. 2. 2. 23:26
반응형

www.acmicpc.net/problem/1660

 

1660번: 캡틴 이다솜

캡틴 이다솜은 자신의 해적선에 적을 공격하기 위한 대포알을 많이 보관해 놓는다. 다솜이는 미적감각이 뛰어나기 때문에, 대포알은 반드시 사면체 모양으로 쌓아놓아야 한다고 생각한다. 사면

www.acmicpc.net

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.util.Arrays;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) throws FileNotFoundException {
		Main m = new Main();
		m.doit();
	}
	
	
	
	int t[] = new int[130];
	int s[] = new int[130];
	
	int MAX = 300001;
	int m[] = new int[MAX];
	int N;
	
	public void doit() throws FileNotFoundException{
		//System.setIn(new FileInputStream("input.txt"));
		Scanner sc = new Scanner(System.in);
		N = sc.nextInt();
		
		t[1] = 1;
		t[2] = 3; // t[1] + 2
		t[3] = 6; // t[2] + 3
		
		int sum = t[1];
		s[1] = sum;
		int count = 1;
		while(sum <= N){
			s[count] = sum;
			count++;
			t[count] = t[count - 1] + count;
			sum += t[count];
			
		}
//		System.out.println(count);
//		print(t);
//		print(s);
		for(int i = 0; i <= N; i++){
			m[i] = MAX;
		}
		
		for(int i = 1; i < count; i++){
			m[s[i]] = 1; 
			
			for(int j = s[i]; j <= N; j++){
				m[j] = Math.min(m[j], m[j-s[i]] + 1);
			}
		}
		
//		printM(s[count-1]);
		System.out.println(m[N]);
//		for(int i = 1; i <= N; i++){
//			for(int j = 1; j < count; j++){
//				m[i][j] = 
//			}
//		}
	}
	
	void print(int [] a){
		System.out.println(Arrays.toString(a));
	}
	
	void printM(int c){
		for(int i = 0; i <= c; i++){
			System.out.print(m[i] + ", ");
		}
		System.out.println();
	}
}
반응형