Hyemi Lee

Hyemi Lee

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

Algorithm, boj, 퇴사(14501), 퇴사2(15486)

퇴사

brute force

  • 해당 일을 하거나 안하거나 두개로 나눌수있다.
  • 해당일의 가격 , 오늘 + 해당일이 걸리는 날짜
  • 해당일전날의 가격, 오늘+1
// solve(1,0) 으로 시작 , 1일차에는 받은 pay가 없다.
private static void solve(int today, int totalPay) {
		max = Math.max(max, totalPay);
		if (today > N) {
			return;
		}
		// 오늘 받은 일을 해본다.
		// 당일에 1일치 일을 할수있으므로 -1을 해준다.
		// N=10, today=10, arr[10][0] = 1이라면
		// 10일에 1일치 일을 할수있다.
		if (today + arr[today][0] - 1 <= N) {
			solve(today + arr[today][0], totalPay + arr[today][1]);
		}
		// 오늘 받은일을 하지 않는다.
		solve(today + 1, totalPay);
	}

퇴사2

int[] dp = new int[N + 2];
//------------------------------
//-- 1. brute force 방법을 그대로 이용
//------------------------------
for (int day = 1; day <= N; day++) {
 int nextDay = day + arr[day][0];
 if (nextDay - 1 <= N) {
 dp[nextDay] = Math.max(dp[day] + arr[day][1], dp[nextDay]);
 }
 dp[day + 1] = Math.max(dp[day + 1], dp[day]);
}
// 마지막 날 전 까지 일했거나 , 마지막날에도 일했을때
max = Math.max(dp[N + 1], dp[N]);
//------------------------------
//-- 2. dp[day] : day전날까지 일했을때 제일 큰 pay
//------------------------------
dp = new int[N + 2];
max = 0;
for (int day = 1; day <= N; day++) {
 max = Math.max(max, dp[day]);
 int nextDay = day + arr[day][0];
 if (nextDay - 1 <= N) {
 // 오늘도 일했을때 값 vs 오늘안하고 내일 일했을때 값
 dp[nextDay] = Math.max( max + arr[day][1], dp[nextDay]);
 }
}		
System.out.println(max);

전체 코드

// 15486, 14501
package org.baekjoon;
import java.util.Scanner;
public class test14501 {
	static int N, max;
	static int[][] arr;
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		N = sc.nextInt();
		arr = new int[N + 1][2];
		for (int i = 1; i <= N; i++) {
			arr[i][0] = sc.nextInt(); // T
			arr[i][1] = sc.nextInt(); // P
		}
		max = 0;
		//-- brute force
		// solve(1, 0);
		//-- dp
		int[] dp = new int[N + 2];
		//-- 1. brute force 방법을 그대로 이용
		for (int day = 1; day <= N; day++) {
			int nextDay = day + arr[day][0];
			if (nextDay - 1 <= N) {
				dp[nextDay] = Math.max(dp[day] + arr[day][1], dp[nextDay]);
			}
			dp[day + 1] = Math.max(dp[day + 1], dp[day]);
		}
		// 마지막 날 전 까지 일했거나 , 마지막날에도 일했을때
		max = Math.max(dp[N + 1], dp[N]);
		//-- 2. dp[day] : day전날까지 일했을때 제일 큰 pay
		dp = new int[N + 2];
		max = 0;
		for (int day = 1; day <= N; day++) {
			max = Math.max(max, dp[day]);
			int nextDay = day + arr[day][0];
			if (nextDay - 1 <= N) {
				// 오늘도 일했을때 값 vs 오늘안하고 내일 일했을때 값
				dp[nextDay] = Math.max( max + arr[day][1], dp[nextDay]);
			}
		}		
		System.out.println(max);
	}
	private static void solve(int today, int totalPay) {
		max = Math.max(max, totalPay);
		if (today > N) {
			return;
		}
		// 오늘 받은 일을 해본다.
		// 당일에 1일치 일을 할수있으므로 -1을 해준다.
		// N=10, today=10, arr[10][0] = 1이라면
		// 10일에 1일치 일을 할수있다.
		if (today + arr[today][0] - 1 <= N) {
			solve(today + arr[today][0], totalPay + arr[today][1]);
		}
		// 오늘 받은일을 하지 않는다.
		solve(today + 1, totalPay);
	}
}

참고

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...