230717 연속 펄스 부분 수열의 합

Jongleee·2023년 7월 17일
0

TIL

목록 보기
313/737
public long solution(int[] sequence) {
	int n = sequence.length;

	long[] dp0 = new long[n];
	long[] dp1 = new long[n];

	dp0[0] = pulseMultiNumber(0, 0, sequence);
	dp1[0] = pulseMultiNumber(1, 0, sequence);
	long answer = Math.max(dp0[0], dp1[0]);

	for (int i = 1; i < n; i++) {
		long cal0 = pulseMultiNumber(0, i, sequence);
		long cal1 = pulseMultiNumber(1, i, sequence);

		dp0[i] = Math.max(cal0, dp0[i - 1] + cal0);
		dp1[i] = Math.max(cal1, dp1[i - 1] + cal1);

		answer = Math.max(answer, Math.max(dp0[i], dp1[i]));
	}

	return answer;
}

private long pulseMultiNumber(int k, int i, int[] sequence) {
    int multiplier = (i % 2 == 0) ? 1 : -1;
    if (k == 0)
        multiplier *= -1;
	return sequence[i] * multiplier;
}

출처:https://school.programmers.co.kr/learn/courses/30/lessons/161988

1개의 댓글

comment-user-thumbnail
2023년 7월 18일

덕분에 좋은 정보 얻어갑니다, 감사합니다.

답글 달기