Hyemi Lee

Hyemi Lee

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

Algorithm, boj, 점프(1890)

틀린이유

  • result 변수를 매번 생성하지말고 곧장 dp에 저장하는 방법으로 변경해야 한다.
  • dp의 초기값은 -1 : 해당 지점은 지나간적이 없다.
  • 해당 지점을 지나갈때 dp의 초기값을 0으로 변경해주고 지나가면서 곧장 경우의 수를 더해준다.
int result = 0;
result += fun(nextX, nextY);
dp[x][y] = 0;
dp[x][y] += fun(nextX, nextY);
package org.baekjoon;
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class test1890_dp_jump {
	static int[] nx = {1,0};
	static int[] ny = {0,1};
	static int N;
	static int[][] arr = new int[101][101];
	static long[][] dp = new long[101][101];
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		N = Integer.parseInt(br.readLine());
		String str[];
		for (int i=0; i<N; i++) {
			str = br.readLine().split(" ");
	 for (int j = 0; j < N; j++) {
	 arr[i][j] = Integer.parseInt(str[j]);
				dp[i][j] = -1;
			}
		}
		System.out.println( fun(0,0) );
	}
	public static long fun(int x, int y) {
		// 목적지에 도착 시 경우의 수 1반환
		if(x == N-1 && y == N-1)
			return 1;
		// 이 지점 부터 목적지까지 가는 경로의 개수가 있다면 해당 경로의 개수 반환.
		// -> 이 지점 부터 목적지까지는 가는 경로의 개수가 이미 있기 때문에 또 다시 경로의 개수를 세어줄 필요 없이 바로 사용
		if (dp[x][y] > -1)
			return dp[x][y];
		// 이 지점에서 목적지까지 갈 수 있는 경우의 수
		dp[x][y] = 0;
		for (int i=0; i<2; i++) {
			int nextX = x + ( arr[x][y] * nx[i] );
			int nextY = y + ( arr[x][y] * ny[i] );
			// 이 지점에서 목적지까지 오른쪽 또는 아래쪽으로 이동해서 갈 수 있으므로 그 경우를 모두 더한다
			dp[x][y] += fun(nextX, nextY);
		}
		// 경로의 개수를 dp배열에 저장 , 메모이제이션 기법 사용
		return dp[x][y];
	}
}

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