Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Algorithm, boj, 알약(4811)

문제바로가기

[문제]
70세 박종수 할아버지는 매일 매일 약 반알을 먹는다.
손녀 선영이는 종수 할아버지에게 약이 N개 담긴 병을 선물로 주었다.
첫째 날에 종수는 병에서 약 하나를 꺼낸다.
그 다음, 그 약을 반으로 쪼개서 한 조각은 먹고, 다른 조각은 다시 병에 넣는다.
다음 날부터 종수는 병에서 약을 하나 꺼낸다.
(약은 한 조각 전체 일 수도 있고, 쪼갠 반 조각 일 수도 있다) 반 조각이라면 그 약을 먹고,
아니라면 반을 쪼개서 한 조각을 먹고, 다른 조각은 다시 병에 넣는다.
종수는 손녀에게 한 조각을 꺼낸 날에는 W를, 반 조각을 꺼낸 날에는 H 보낸다.
손녀는 할아버지에게 받은 문자를 종이에 기록해 놓는다.
총 2N일이 지나면 길이가 2N인 문자열이 만들어지게 된다.
이때, 가능한 서로 다른 문자열의 개수는 총 몇 개일까?
[입력]
입력은 최대 1000개의 테스트 케이스로 이루어져 있다.
각 테스트 케이스는 한 줄이며, 병에 들어있는 약의 개수 N ≤ 30 가 주어진다.
입력의 마지막 줄에는 0이 하나 주어진다.

나의 문제

  • 문제를 제대로 읽자
  • 예제를 통해서 점화식을 찾으려는 시도는 좋았다
  • 예제가 도출되기 어렵다면 큰 범위에서 미지수를 생각해서 풀어보자

해결

full : 알약 전체짜리
half : 알약 반쪽짜리
1. full == 0 이면 ,
더이상 먹을약이 없거나 half로만 이루어진다. 따라서 1
2. full짜리를 반쪽 베어먹는다면, 반쪽짜리는 하나 증가
pillArray[full-1][half+1]
3. 반쪽짜리를 먹으면, 반쪽 짜리 하나 감소, 전체짜리는 변동없음
pillArray[full][half]

코드

package org.baekjoon;
import java.util.Scanner;
public class test4811 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int test_case = sc.nextInt();
		while(test_case > 0) {
			test_case--;
			int n = sc.nextInt();
			// 2n일 동안 먹는다
			long[][] pillArray = new long[2*n+1][2*n+1];
			int full = n-1; // 처음에 반알을 먹으므로 전체는 -1
			int half = 1; // 처음에 반알을 먹으므로 반알짜리가 하나 생긴다.
			System.out.println(n+" : "+pillCnt(full, half, pillArray));
		}
	}
	private static long pillCnt(int full, int half, long[][] pillArray) {
		if(full > 0 ) {
			if(pillArray[full][half] != 0)
				return pillArray[full][half];
		}
		// 전체 알약이 없으면 반알씩 먹는방법뿐이므로 return 1
		if( full == 0) {
			pillArray[full][half] = 1;
			return 1;
		}
		else {
			long sum = 0;
			// 전체의 반을 먹음면 전체-1 반짜리+1
			sum += pillCnt(full-1, half+1, pillArray);
			// 반쪽짜리가 있으면
			if(half > 0)
				sum += pillCnt(full, half-1, pillArray);
			pillArray[full][half] = sum;
			return pillArray[full][half];
		}
	}
}

Reference

Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...