2025.05.20
점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다. 다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다. 학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있습니다. 예를 들어, 4번 학생은 3번 학생이나 5번 학생에게만 체육복을 빌려줄 수 있습니다. 체육복이 없으면 수업을 들을 수 없기 때문에 체육복을 적절히 빌려 최대한 많은 학생이 체육수업을 들어야 합니다.
전체 학생의 수 n, 체육복을 도난당한 학생들의 번호가 담긴 배열 lost, 여벌의 체육복을 가져온 학생들의 번호가 담긴 배열 reserve가 매개변수로 주어질 때, 체육수업을 들을 수 있는 학생의 최댓값을 return 하도록 solution 함수를 작성해주세요.

배열이 정렬되있지 않은 경우를 고려하지 않음
import java.util.Map;
import java.util.HashMap;
class Solution {
public int solution(int n, int[] lost, int[] reserve) {
int answer = n - lost.length;
Map<Integer, Integer> reserves = new HashMap<>();
for (int i = 0; i < reserve.length; i++) {
reserves.put(reserve[i], 1);
}
for (int i = 0; i < lost.length; i++) {
int stu = lost[i];
Integer stu1 = reserves.get(stu - 1);
Integer stu2 = reserves.get(stu + 1);
if (stu1 != null && stu1 != 0) {
answer++;
reserves.put(stu - 1, 0);
}
else if (stu2 != null && stu2 != 0) {
answer++;
reserves.put(stu + 1, 0);
}
}
return answer;
}
}
여분의 체육복을 가지고 있는
학생이 체육복을 도난당한 경우의 수를 고려하지 않음
import java.util.Map;
import java.util.HashMap;
import java.util.Arrays;
class Solution {
public int solution(int n, int[] lost, int[] reserve) {
int answer = n - lost.length;
Map<Integer, Integer> reserves = new HashMap<>();
Arrays.sort(lost);
Arrays.sort(reserve);
for (int i = 0; i < reserve.length; i++) {
reserves.put(reserve[i], 1);
}
for (int i = 0; i < lost.length; i++) {
int stu = lost[i];
Integer stu1 = reserves.get(stu - 1);
Integer stu2 = reserves.get(stu + 1);
if (stu1 != null && stu1 != 0) {
answer++;
reserves.put(stu - 1, 0);
}
else if (stu2 != null && stu2 != 0) {
answer++;
reserves.put(stu + 1, 0);
}
}
return answer;
}
}
여벌의 체육복을 가지고 있는 학생을 구분했지만,
아래 반복문에서 사라지지 않고 다시 체육복을 빌리고 있음
import java.util.Map;
import java.util.HashMap;
import java.util.Arrays;
class Solution {
public int solution(int n, int[] lost, int[] reserve) {
int answer = n - lost.length;
Map<Integer, Integer> reserves = new HashMap<>();
Arrays.sort(lost);
Arrays.sort(reserve);
for (int i = 0; i < reserve.length; i++) {
reserves.put(reserve[i], 1);
}
for (int i = 0; i < lost.length; i++) { // 여벌의 체육복을 가지고 있는 학생이 도난당했을 경우
int stu = lost[i];
if (reserves.get(stu) != null) {
answer++;
reserves.put(stu, 0);
}
}
for (int i = 0; i < lost.length; i++) {
int stu = lost[i];
Integer stu1 = reserves.get(stu - 1);
Integer stu2 = reserves.get(stu + 1);
if (stu1 != null && stu1 != 0) { // 도난당한 학생의 앞번호 학생이 여벌의 체육복을 가지고 있는 경우
answer++;
reserves.put(stu - 1, 0);
}
else if (stu2 != null && stu2 != 0) { // 도난당한 학생의 뒷번호 학생이 여벌의 체육복을 가지고 있는 경우
answer++;
reserves.put(stu + 1, 0);
}
}
return answer;
}
}
import java.util.Map;
import java.util.HashMap;
import java.util.Arrays;
class Solution {
public int solution(int n, int[] lost, int[] reserve) {
int answer = n - lost.length;
Map<Integer, Integer> reserves = new HashMap<>();
Arrays.sort(lost);
Arrays.sort(reserve);
for (int i = 0; i < reserve.length; i++) {
reserves.put(reserve[i], 1);
}
for (int i = 0; i < lost.length; i++) { // 여벌의 체육복을 가지고 있는 학생이 도난당했을 경우
int stu = lost[i];
if (reserves.get(stu) != null) {
answer++;
reserves.put(stu, 0);
}
}
for (int i = 0; i < lost.length; i++) {
int stu = lost[i];
Integer stu1 = reserves.get(stu - 1);
Integer stu2 = reserves.get(stu + 1);
if (stu1 != null && stu1 != 0) { // 도난당한 학생의 앞번호 학생이 여벌의 체육복을 가지고 있는 경우
answer++;
reserves.put(stu - 1, 0);
}
else if (stu2 != null && stu2 != 0) { // 도난당한 학생의 뒷번호 학생이 여벌의 체육복을 가지고 있는 경우
answer++;
reserves.put(stu + 1, 0);
}
}
return answer;
}
}
boolean을 이용해 인덱스 직접 접근 없이 해결
class Solution {
public int solution(int n, int[] lost, int[] reserve) {
boolean[] lostArr = new boolean[n + 2];
boolean[] reserveArr = new boolean[n + 2];
for (int l : lost) lostArr[l] = true;
for (int r : reserve) reserveArr[r] = true;
// 여벌 가진 학생이 도난당한 경우
for (int i = 1; i <= n; i++) {
if (lostArr[i] && reserveArr[i]) {
lostArr[i] = false;
reserveArr[i] = false;
}
}
// 앞뒤 학생에게 빌려주기
for (int i = 1; i <= n; i++) {
if (reserveArr[i]) {
if (lostArr[i - 1]) {
lostArr[i - 1] = false;
reserveArr[i] = false;
} else if (lostArr[i + 1]) {
lostArr[i + 1] = false;
reserveArr[i] = false;
}
}
}
int count = 0;
for (boolean l : lostArr) if (l) count++;
return n - count;
}
}