Coding Test/프로그래머스

[LEVEL 1] 모의고사 - Python

크라슐라 2022. 9. 13. 23:11

모의고사

 

1. 문제 설명

 

    '수포자'는 수학을 포기한 사람의 준말입니다. '수포자' 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. '수포자'는 1번 문제부터 마지막 문제까지 다음과 같이 찍습니다.

 

    ● 1번 '수포자'가 찍는 방식: 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, …

    ● 2번 '수포자'가 찍는 방식: 2, 1, 2, 3, 2, 4, 2, 5, 2, 1, 2, 3, 2, 4, 2, 5, …

    ● 3번 '수포자'가 찍는 방식: 3, 3, 1, 1, 2, 2, 4, 4, 5, 5, 3, 3, 1, 1, 2, 2, 4, 4, 5, 5, …

 

    1번 문제부터 마지막 문제까지의 정답이 순서대로 들어 있는 배열 answers가 주어졌을 때, 가장 많은 문제를 맞힌 사람이 누구인지 배열에 담아 반환(Return)하도록 solution 함수를 작성해주세요.

 

2. 제한사항

 

    ● 시험은 최대 10,000문제로 구성되어 있습니다.

    ● 문제의 정답은 1, 2, 3, 4, 5 중 하나입니다.

    ● 가장 높은 점수를 받은 사람이 여럿일 경우, 반환(Return)하는 값을 오름차순 정렬해주세요.

 

3. 답안

 

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
def solution(answers):
 
    # '수포자' 별 정답을 찍는 방식을 정리한 리스트 생성
    person_1 = [12345]
    person_2 = [21232425]
    person_3 = [3311224455]
 
    # 정답을 맞힌 개수를 저장할 result 리스트와 반환 값을 담을 answer 리스트 초기화
    result = [0* 3
    answer = []
 
    # for 반복문을 통해 '수포자' 별로 맞힌 문제 수 계산
    for i in range(len(answers)):
        if answers[i] == person_1[i % len(person_1)]:
            result[0+= 1
        if answers[i] == person_2[i % len(person_2)]:
            result[1+= 1
        if answers[i] == person_3[i % len(person_3)]:
            result[2+= 1
 
    # for 반복문을 통해 가장 많은 문제를 맞힌 사람을 answer 리스트에 추가
    for j in range(len(result)):
        if max(result) == result[j]:
            answer.append(j + 1)
 
    # 결과 값 반환
    return answer

 

4. 해설

 

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
def another_solution(answers):
 
    # '수포자' 별 정답을 찍는 방식을 정리한 리스트 생성
    pattern1 = [12345]
    pattern2 = [21232425]
    pattern3 = [3311224455]
 
    # 정답을 맞힌 개수를 저장할 scores 리스트와 반환 값을 담을 answer 리스트 초기화
    scores = [000]
    answer = []
 
    # enumerate() 함수를 통해 인덱스와 값에 대하여 반복문을 적용하고, 맞힌 문제 수 계산
    for index, number in enumerate(answers):
        if number == pattern1[index % len(pattern1)]:
            scores[0+= 1
        if number == pattern2[index % len(pattern2)]:
            scores[1+= 1
        if number == pattern3[index % len(pattern3)]:
            scores[2+= 1
 
    # enumerate() 함수를 통해 인덱스와 값에 대하여 반복문을 적용하고, 결과 값 도출
    for index, score in enumerate(scores):
        if score == max(scores):
            answer.append(index + 1)
 
    # 결과 값 반환
    return answer