250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- Set
- AB테스트
- 데이터전처리
- 아티클스터디
- 가설검정
- Leetcode
- ★
- 반복문
- 내일배움캠프
- 한줄for문
- DATE_SUB
- Join
- 내일배움일지
- 프로그래머스
- 선형회귀
- 리스트
- Max
- f-string
- 통계학
- 태블로
- SQL
- 다중공선성
- Til
- map
- SQLD
- 내배캠_학습기록
- 데이터시각화
- python
- 이중for문
- 시각화
Archives
- Today
- Total
노력에는 지름길이 없으니까요
프로그래머스 - 최빈값 구하기 Python ver. 본문
728x90
해결일 | 언어 | 레벨 | 테스트명 |
20240617 | Python | level 0 | 최빈값 구하기 |
링크 : https://school.programmers.co.kr/learn/courses/30/lessons/120812
내 코드
def solution(array):
temp = {num:array.count(num) for i,num in enumerate(array)}
mval = max(temp.values())
count, answer =0,0
for k, v in temp.items():
if v==mval:
count+=1
answer=k
return -1 if count >1 else answer
개선점: 최빈값 구하는 법이 생각이 안나서 구구절절 코드 또 써버림 ㅋㅋ
베스트 코드
def solution(array):
while len(array) != 0:
for i, a in enumerate(set(array)):
array.remove(a)
if i == 0: return a
return -1
코드설명
-> set을 이용하여 배열의 모든 원소를 한 개씩 모두 소거해 나가면서 최종적으로 값의 종류가 1개가 남을 경우(최빈값) i=0이므로 해당 값을 반환하고, 값의 종류가 두 개 이상이 남을 경우 i가 1이상이 되므로 -1을 반환합니다. [3, 3, 3, 1, 2]일때 한 번 반복을 돌면 원소의 종류[1, 2, 3]을 한 번씩 제거하고 [3, 3]이 됩니다. set([3, 3])은 (3)이 되므로 그럼 i는 0에서 끝납니다.
728x90
반응형
'Python > 프로그래머스' 카테고리의 다른 글
프로그래머스 - 점의 위치 구하기 Python ver. (0) | 2024.07.09 |
---|---|
프로그래머스 - 숨어있는 숫자의 덧셈 (2) Python ver. (0) | 2024.07.09 |
프로그래머스 - 암호 해독 Python ver. (0) | 2024.07.08 |
프로그래머스 - 분수의 덧셈 Python ver. (0) | 2024.07.08 |
프로그래머스 - 명예의 전당 (1) Python ver. (0) | 2024.07.05 |