업데이트:

문제 93

93. 이상한 출석 번호 부르기 1

정보 선생님은 수업을 시작하기 전에 이상한 출석을 부른다.
선생님은 출석부를 보고 번호를 부르는데, 학생들의 얼굴과 이름을 빨리 익히기 위해 번호를 무작위(랜덤)으로 부른다.
그리고 얼굴과 이름이 잘 기억되지 않는 학생들은 번호를 여러 번 불러 이름과 얼굴을 빨리 익히려고 하는 것이다.
출석 번호를 n번 무작위로 불렀을 때, 각 번호(1 ~ 23)가 불린 횟수를 각각 출력해보자.

  • 입력
    첫 번째 줄에 출석 번호를 부른 횟수인 정수 n이 입력된다. (1 ~ 10000)
    두 번째 줄에는 무작위로 부른 n개의 번호(1 ~ 23)가 공백을 두고 순서대로 입력된다.

    10
    1 3 2 2 5 6 7 4 5 9

  • 출력
    1번부터 번호가 불린 횟수를 순서대로 공백으로 구분하여 한 줄로 출력한다.

    1 2 1 1 2 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0

TIP

파이썬에서는 배열의 비어있는 공간을 미리 확보해 놓을 수 없다.따라서 필요한 갯수 만큼 ‘어떠한 값’으로 초기화 시켜주어야 한다.

LIST = list(range(23)) # 0~22번지까지 0-22의 숫자들로 채워진다.

LIST = [0 for _ in range(23)] # 0~22번지까지 0으로 채워진다.

호출되는 번호(주소값)의 값을 기존 값에서 +1하여 저장해주는 방식으로 해당 번호가 몇 번 호출되었는지 카운트할 수 있다.

아래 코드에서 '*(Asterisk)'를 사용한 이유

문제에서 원하는 출력값은 리스트 형태가 아닌, 내부의 원소를 그대로 출력하길 요구했기 때문이다.

print( [1,2,3] ) # [1,2,3]

print( *[1,2,3] ) # 1 2 3

풀이

# 답
result = [0 for _ in range(23)]
n = int(input())
bunhos = map(int, input().split()[:n])

for bunho in range(bunhos):
    result[bunho-1] += 1

print(*result)

# 나의 답
result = [0 for _ in range(23)]
n = int(input())
bunho = list(map(int, input().split()[:n]))

for i in range(n):
    for j in range(23):
        if bunho[i] == j:
            result[j] += 1

print(*result)

정말 간단하게 풀 수 있는 문제를 너무 돌아돌아 풀었다.

문제 94

94. 이상한 출석 번호 부르기 2

출석 번호를 n번 무작위로 불렀을 때, 부른 번호를 거꾸로 출력해 보자.

  • 입력
    첫 번째 줄에 출석 번호를 부른 횟수인 정수 n이 입력된다. (1 ~ 10000)
    두 번째 줄에는 무작위로 부른 n개의 번호(1 ~ 23)가 공백을 두고 순서대로 입력된다.

    10
    10 4 2 3 6 6 7 9 8 5

  • 출력
    출석을 부른 번호 순서를 바꾸어 공백을 두고 출력한다.

    5 8 9 7 6 6 3 2 4 10

TIP

리스트의 메소드인 reverse()를 이용하면 된다.

풀이

n = int(input())
bunho = input().split()
bunho.reverse()

print(*bunho)

문제 95

95. 이상한 출석 번호 부르기 3

출석 번호를 n번 무작위로 불렀을 때, 가장 빠른 번호를 출력해 보자.

  • 입력
    첫 번째 줄에 출석 번호를 부른 횟수인 정수 n이 입력된다. (1 ~ 10000)
    두 번째 줄에는 무작위로 부른 n개의 번호(1 ~ 23)가 공백을 두고 순서대로 입력된다.

    10
    10 4 2 3 6 6 7 9 8 5

  • 출력
    출석을 부른 번호 중에 가장 빠른 번호를 1개만 출력한다.

    2

TIP

가장 작은 값을 찾으면 된다.

파이썬에서는 배열(iterable) 객체의 원소 중 가장 작은 값을 반환해주는 min() 함수를 제공하고 있다.

풀이

n = int(input())
bunho = input().split()

print(min(bunho))

함수가 있어서 쉽게 풀 수 있었다.

Notice: 이 게시물은 우리밋_woorimIT님의 유튜브를 참고하였습니다.

댓글남기기