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