문제설명
점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다.
다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다.
학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있습니다.
예를 들어, 4번 학생은 3번 학생이나 5번 학생에게만 체육복을 빌려줄 수 있습니다.
체육복이 없으면 수업을 들을 수 없기 때문에 체육복을 적절히 빌려 최대한 많은 학생이 체육수업을 들어야 합니다.
전체 학생의 수 n, 체육복을 도난당한 학생들의 번호가 담긴 배열 lost, 여벌의 체육복을 가져온 학생들의 번호가 담긴 배열 reserve가 매개변수로 주어질 때, 체육수업을 들을 수 있는 학생의 최댓값을 return 하도록 solution 함수를 작성해주세요.
주의사항
- 전체 학생의 수는 2명 이상 30명 이하입니다.
- 체육복을 도난당한 학생의 수는 1명 이상 n명 이하이고 중복되는 번호는 없습니다.
- 여벌의 체육복을 가져온 학생의 수는 1명 이상 n명 이하이고 중복되는 번호는 없습니다.
- 여벌 체육복이 있는 학생만 다른 학생에게 체육복을 빌려줄 수 있습니다.
- 여벌 체육복을 가져온 학생이 체육복을 도난당했을 수 있습니다. 이때 이 학생은 체육복을 하나만 도난당했다고 가정하며, 남은 체육복이 하나이기에 다른 학생에게는 체육복을 빌려줄 수 없습니다.
입출력예시
코드
내코드는....75점 받았다...ㅋㅋㅋ 테스트 12개 중에 3개 실패,,
인기많은 코드도 12번하나가 통과가 안된다. 다른건 되겠지만,, 너무 길기에 리뷰 실패..
function solution(n, lost, reserve) {
let inStudent = [];
for(let i=1; i<=n ; i++){
if(!lost.includes(i)){
inStudent.push(i)
}}
for(let i=0; i< lost.length;i++){
if(reserve.includes(lost[i]-1)){
inStudent.push(lost[i])
reserve.splice(reserve.indexOf(lost[i]-1),1);
} else if(reserve.includes(lost[i]+1)){
inStudent.push(lost[i])
reserve.splice(reserve.indexOf(lost[i]+1),1);
}
console.log("for inStudent :", inStudent)
console.log("lost[i] : ", lost[i])
}
let answer = inStudent.length;
return answer;
}
해석
1. 학생수가 n명이고 lost 들어있지 않은 학생들을 제외하곤 체육수업에 참여할 수 있기에 for문을 돌려 제거해준다.
2. lost의 길이만큼 반복문을 돌며 lost[i]-1, lost[i]+1 의 수가 reverse에 있는지 찾는다.
3. 있을 경우에는 inSudent에 lost[i]번도 참여할 수 있다는 것이니 inStudent에 넣어준다.
4. 그리고 다음 반복을 할때 reverse에서 lost에게 옷을 빌려준 애는 또 빌려줄수 없기때문에 그 번호를 제외한 배열이 만들어져야한다.
5. 2, 3, 4번 반복한다
6.그리고 inStudent의 길이만큼 리턴한다.
한줄평
이번 문제는 어려웠다. 탐욕법을 모르는 상태에서 이문제에 접근하려니 만만치 않다.
console.log로 여러번 테스트 했을땐 잘 맞는다
*탐욕법 공부하자...
링크
https://programmers.co.kr/learn/courses/30/lessons/42862
'개발 공부 > 알고리즘 개념+문제풀이' 카테고리의 다른 글
[프로그래머스 2단계 문제] 기능개발 (0) | 2021.06.21 |
---|---|
[알고리즘] 음양 구하기_프로그래머스 1단계 (0) | 2021.06.21 |
[알고리즘] K번째수_프로그래머스 1단계 (0) | 2021.06.20 |
[알고리즘] 폰켓몬_프로그래머스 1단계 (0) | 2021.06.20 |
[알고리즘] 내적_프로그래머스 1단계 (0) | 2021.06.20 |
댓글