점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다. 다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다. 학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있습니다. 예를 들어, 4번 학생은 3번 학생이나 5번 학생에게만 체육복을 빌려줄 수 있습니다. 체육복이 없으면 수업을 들을 수 없기 때문에 체육복을 적절히 빌려 최대한 많은 학생이 체육수업을 들어야 합니다.
전체 학생의 수 n, 체육복을 도난당한 학생들의 번호가 담긴 배열 lost, 여벌의 체육복을 가져온 학생들의 번호가 담긴 배열 reserve가 매개변수로 주어질 때, 체육수업을 들을 수 있는 학생의 최댓값을 return 하도록 solution 함수를 작성해주세요.
n lost reserve return
5 [2, 4] [1, 3, 5] 5
5 [2, 4] [3] 4
3 [3] [1] 2
입출력 예 설명
예제 #1
1번 학생이 2번 학생에게 체육복을 빌려주고, 3번 학생이나 5번 학생이 4번 학생에게 체육복을 빌려주면 학생 5명이 체육수업을 들을 수 있습니다.
예제 #2
3번 학생이 2번 학생이나 4번 학생에게 체육복을 빌려주면 학생 4명이 체육수업을 들을 수 있습니다.
이번 문제는 1부터 n까지의 숫자를 하나씩 순회하면서 만약 숫자가 lost에 있을 경우 reserve에 현재수, 현재수-1, 현재수+1 중 하나가 존재하면 답을 세는 변수를 1 증가시켜주고 reserve가 중복으로 빌려주는 것을 막기위해 reserve에서 지워주었다.
테스트 5, 12에서 오답처리가 되어서 문제를 보니 만약 reserve에도 포함되어 있고 lost에도 포함되어 있는 학생이 있다면 이 학생은 자신의 여분 옷을 자신이 입기 때문에 앞서 짰던 로직대로 굴러가지 않는다.
이를 위해 숫자를 순회하기 전에 lost를 순회하며 reserve와 겹치는 수를 제거해주었다.
def solution(n, lost, reserve):
answer = 0
for i in lost:
if i in reserve:
lost.remove(i)
reserve.remove(i)
for i in range(1, n+1):
if i in lost:
if i in reserve:
answer+=1
reserve.remove(i)
elif i-1 in reserve:
answer+=1
reserve.remove(i-1)
elif i+1 in reserve:
answer+=1
reserve.remove(i+1)
else:
answer+=1
return answer