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
- c언어 괄호검사
- C언어 스택 연산
- getline()함수
- 네트워크 결합
- 문자형 배열
- 범위 기반 for문
- LAN의 분류
- 유형 변환
- string유형
- 백준 파이썬
- C언어 덱
- 문제해결 단계
- 운영체제 기능
- 원형 연결 구조 연결된 큐
- C언어 계산기 프로그램
- r-value참조자
- const l-value참조자
- auto 키워드
- 알고리즘 조건
- 주기억장치
- const화
- 프로그래머스 푸드 파이트 대회
- 괄호 검사 프로그램
- 입출력 관리자
- 프로그래머스 배열만들기4
- 회전 및 자리 이동 연산
- 값/참조/주소에 의한 전달
- 논리 연산
- l-value참조자
- IPv4 주소체계
Archives
- Today
- Total
chyam
[프로그래머스 Lv2,python]- 귤 고르기 본문

def solution(k, tan):
dic={}
tan_set=set(tan) #집합으로 저장하기
li=[] # 딕셔너리의 값을 저장할곳
cnt=0 #개수 저장
for a in tan_set: #딕셔너리에 값 추가
dic[a]=0
for a in tan: #개수 추가
dic[a]+=1
for key,value in dic.items():
li.append(value) # 개수를 리스트로 저장
li.sort(reverse=True) # 내림차순
while(k>0):
k-=li[cnt]
cnt+=1
return cnt
counter을 사용하지않고 구현했음. 아래는 counter을 사용한 풀이임.
counter을 사용하면 딕셔너리 형태로 개수를 {1:2, 2:1 } 이런식으로 횟수를 알수있다.
def solution(k, tan):
from collections import Counter
counts = Counter(tan)
# 등장 횟수를 내림차순으로 정렬
sorted_counts = sorted(counts.values(), reverse=True)
# 최소한의 요소 개수를 선택
cnt = 0
for count in sorted_counts:
k -= count
cnt += 1
if k <= 0: # k가 0 이하로 떨어지면 종료
break
return cnt
'프로그래머스 > LV2' 카테고리의 다른 글
[프로그래머스 Lv2,python]- 예상대진표 (0) | 2024.12.31 |
---|---|
[프로그래머스 Lv2, python]- 멀리 뛰기 (0) | 2024.12.30 |
[프로그래머스 Lv2, python]- 구명보트 (1) | 2024.12.28 |
[프로그래머스 Lv2, python]- 영어 끝말잇기 (1) | 2024.12.28 |
[프로그래머스 Lv2, python]- N개의 최소공배수 (0) | 2024.12.27 |