Coding Test/programmers

[프로그래머스] 스타수열

Karla Ko 2023. 8. 10. 22:10
728x90

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

 

프로그래머스

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

programmers.co.kr

 

 

풀이

from collections import Counter
def solution(a):
    answer = 0

    if len(a) <= 1:
        return 0

    c = {i: v for i, v in Counter(a).most_common()}
    
    for i in c:
        if c[i]*2 <= answer: # i의 등장 횟수가 공통인자 횟수 이하
            continue
        cnt = 0
        idx = 0
        while idx < len(a)-1:
            if (a[idx]!=i and a[idx+1]!=i) or a[idx] == a[idx+1]:
                # 집합에 두 값 모두 i가 아님, 집합에 두 값이 같음 -> 스타수열 X
                idx += 1
                continue
            cnt+=2
            idx+=2

        answer = max(answer, cnt)

    return answer
728x90