250x250
Notice
Recent Posts
Recent Comments
관리 메뉴

탁월함은 어떻게 나오는가?

[Algorithm] 연속 펄스 부분 수열의 합 ( Programmers / Python ) 본문

[Snow-ball]프로그래밍(컴퓨터)/Algorithm Training

[Algorithm] 연속 펄스 부분 수열의 합 ( Programmers / Python )

Snow-ball 2024. 3. 29. 17:01
반응형

문제 설명

어떤 수열의연속 부분 수열에 같은 길이의 펄스 수열을 각 원소끼리 곱하여 연속 펄스 부분 수열을 만들려 합니다. 펄스수열이란 [1, -1, 1, -1 ....] 또는 [-1, 1, -1, 1 ....] 과 같이 1 또는 -1로 시작하면서 1과 -1이 번갈아 나오는 수열입니다.

예를 들어 수열 [2, 3, -6, 1, 3, -1, 2, 4]의 연속 부분 수열 [3, -6, 1]에 펄스 수열 [1, -1, 1]을 곱하면 연속 펄스 부분수열은 [3, 6, 1]이 됩니다. 또 다른 예시로 연속 부분 수열 [3, -1, 2, 4]에 펄스 수열 [-1, 1, -1, 1]을 곱하면 연속 펄스 부분수열은 [-3, -1, -2, 4]이 됩니다.

정수 수열 sequence 가 매개변수로 주어질 때, 연속 펄스 부분 수열의 합 중 가장 큰 것을 return 하도록 solution 함수를 완성해주세요.

 

 

 


 

 

 

제한 사항

 

 

 


 

 

 

입출력 예

 

 

 


 

 

 

문제 풀이

연속 펄스 부분 수열의 합 알고리즘문제는 카데인(Kadane's) 알고리즘을 이용해서 풀은 문제였다.

기존의 방법에서는 O(n^2)의 방법으로 풀 수 밖에 없어서 시간초과가 나왔지만, 카데인 알고리즘을 사용하니 O(n)으로 효율이 개선되었다.

 

python:

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
def solution(sequence):
    sequence_r = []
    pivot = True
    for i in range(len(sequence)):
        if pivot:
            sequence_r.append(sequence[i] * 1)
            pivot = False
        else:
            sequence_r.append(sequence[i] * -1)
            pivot = True
 
    current_max = global_max = sequence_r[0]
    current_max2 = global_max2 = sequence_r[0* -1
 
    # 카데인 알고리즘
    for r1 in sequence_r[1:]:
        r2 = -1 * r1
 
        current_max = max(r1, current_max + r1)
        current_max2 = max(r2, current_max2 + r2)
 
        global_max = max(global_max, current_max)
        global_max2 = max(global_max2, current_max2)
 
    return max(global_max2, global_max)
cs

 

 

 

 

 

 

 

 

 

 

 

 

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

반응형
Comments