Notice
Recent Posts
Recent Comments
Link
«   2024/07   »
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
more
Archives
Today
Total
관리 메뉴

김찬양의 개발일지

26일차. 로또의 최고 순위와 최저 순위 본문

코딩테스트/Programmers Level 1

26일차. 로또의 최고 순위와 최저 순위

자유로운영혼이다냥 2023. 12. 20. 21:55

링크

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

 

프로그래머스

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

programmers.co.kr

 


 

문제

 


 

정답

def solution(lottos, win_nums):
    zero = 0
    correct = 0
    for lotto in lottos:
        if lotto == 0:
            zero += 1
        elif lotto in win_nums:
            correct += 1
    return [min(7-(correct+zero), 6), min(7-correct, 6)]

 

풀이과정

 

먼저 로또의 순위는 7-일치하는 번호의 수이다. 다만 7위가 없으므로 min(x, 6)으로 해주면 7은 6으로 처리된다.

자 그러면 최대 순위는 0이 모두 정답일경우, 최소 순위는 0이 모두 오답일 경우이므로 0과 정답인 경우의 수를 센다

zero = 0
correct = 0

for lotto in lottos:
    if lotto == 0:
        zero += 1
    elif lotto in win_nums:
        correct += 1

자 그러면 이제 정답과 0이 모두 정답일경우와 정답만 정답일경우를 출력해주면 된다.

return [min(7-(correct+zero), 6), min(7-correct, 6)]