14. 기초-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:: 파이썬에서는 배열의 비어있는 공간을 미리 확보해 놓을 수 없다.따라서 필요한 갯수 만큼 '어떠한 값'으로 초기화 시켜주어야 한다. ex) LIST = list(range(23)) >> 0~22번지까지 0-22의 숫자들로 채워진다. ex) LIST = [0 for _ in range(23)] >> 0~22번지까지 0으로 채워진다. 호출되는 번호(주소값)의 값을 기존 값에서 +1하여 저장해주는 방식으로 해당 번호가 몇 번 호출되었는지 카운트할 수 있다. 아래 코드에서 '*(Asterisk)'를 사용한 이유 문제에서 원하는 출력값은 리스트 형태가 아닌, 내부의 원소를 그대로 출력하길 요구했기 때문이다.
- 내 풀이)
call = int(input()) randomCall = map(int, input().split()) count = list(range(23)) for n in count: count[n] -= n for i in randomCall: count[i-1] += 1 print(*(count))
-강의 풀이)
n = int(input()) rand = map(int, input().split()) student = [0 for _ in range(23)] for r in rand: student[r-1] += 1 print(*student)
답은 맞지만 리스트를 생성하면서 요솟값을 0으로 초기화하는 방법을 알아두자
- 출석 번호를 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()를 이용하면 된다.
- 내 풀이)
call = int(input()) randomCall = map(int, input().split()) rev = [] for i in randomCall: rev.append(i) rev.reverse() print(*rev)
-강의 풀이)
n = int(input()) rand = list(map(int, input().split())) rand.reverse() print(*rand)
처음 입력 받았을때 list로 묶어주면 번거롭게 리스트를 새로 만들 필요가 없다
- 출석 번호를 n번 무작위로 불렀을 때, 가장 빠른 번호를 출력해 보자.
입력 첫 번째 줄에 출석 번호를 부른 횟수인 정수 n이 입력된다. (1 ~ 10000) 두 번째 줄에는 무작위로 부른 n개의 번호(1 ~ 23)가 공백을 두고 순서대로 입력된다. 10 10 4 2 3 6 6 7 9 8 5
출력 출석을 부른 번호 중에 가장 빠른 번호를 1개만 출력한다. 2
Tip:: 가장 작은 값을 찾으면 된다. 파이썬에서는 배열(iterable) 객체의 원소 중 가장 작은 값을 반환해주는 min() 함수를 제공하고 있다.
- 내 풀이)
# 1 call = int(input()) randomCall = map(int, input().split()) print(min(randomCall)) # 2 call = int(input()) randomCall = map(int, input().split()) min = 23 for i in randomCall: if i <= min: min = i print(min)
-강의 풀이)
n = int(input()) rand = map(int, input().split()) print( min(rand) )
팁을 보고 푼 것과 생각나는 풀이가 있어 두 가지로 나누어 풀어봤다.