[본 문제는 정확성과 효율성 테스트 각각 점수가 있는 문제입니다.]
스노우타운에서 호텔을 운영하고 있는 스카피는 호텔에 투숙하려는 고객들에게 방을 배정하려 합니다. 호텔에는 방이 총 k개 있으며, 각각의 방은 1번부터 k번까지 번호로 구분하고 있습니다. 처음에는 모든 방이 비어 있으며 스카피는 다음과 같은 규칙에 따라 고객에게 방을 배정하려고 합니다.
예를 들어, 방이 총 10개이고, 고객들이 원하는 방 번호가 순서대로 [1, 3, 4, 1, 3, 1] 일 경우 다음과 같이 방을 배정받게 됩니다.
원하는 방 번호 | 배정된 방 번호 |
---|---|
1 | 1 |
3 | 3 |
4 | 4 |
1 | 2 |
3 | 5 |
1 | 6 |
전체 방 개수 k와 고객들이 원하는 방 번호가 순서대로 들어있는 배열 room_number가 매개변수로 주어질 때, 각 고객에게 배정되는 방 번호를 순서대로 배열에 담아 return 하도록 solution 함수를 완성해주세요.
room_number 배열은 모든 고객이 방을 배정받을 수 있는 경우만 입력으로 주어집니다.
k | room_number | result |
---|---|---|
10 | [1,3,4,1,3,1] | [1,3,4,2,5,6] |
function solution(k, room_number) {
const hash = new Map()
const answer = []
for (const number of room_number){
if (!hash.has(number)){
answer.push(number)
hash.set(number, number+1)
} else {
const needUpdateList = []
needUpdateList.push(number)
let cur = hash.get(number)
while (hash.get(cur)){ // cur의 부모 x
needUpdateList.push(cur)
cur = hash.get(cur)
}
answer.push(cur)
for (const v of needUpdateList) hash.set(v, cur+1)
hash.set(cur, cur+1)
}
}
return answer
}
N개의 마을로 이루어진 나라가 있습니다. 이 나라의 각 마을에는 1부터 N까지의 번호가 각각 하나씩 부여되어 있습니다. 각 마을은 양방향으로 통행할 수 있는 도로로 연결되어 있는데, 서로 다른 마을 간에 이동할 때는 이 도로를 지나야 합니다. 도로를 지날 때 걸리는 시간은 도로별로 다릅니다. 현재 1번 마을에 있는 음식점에서 각 마을로 음식 배달을 하려고 합니다. 각 마을로부터 음식 주문을 받으려고 하는데, N개의 마을 중에서 K 시간 이하로 배달이 가능한 마을에서만 주문을 받으려고 합니다. 다음은 N = 5, K = 3인 경우의 예시입니다.
위 그림에서 1번 마을에 있는 음식점은 [1, 2, 4, 5] 번 마을까지는 3 이하의 시간에 배달할 수 있습니다. 그러나 3번 마을까지는 3시간 이내로 배달할 수 있는 경로가 없으므로 3번 마을에서는 주문을 받지 않습니다. 따라서 1번 마을에 있는 음식점이 배달 주문을 받을 수 있는 마을은 4개가 됩니다. 마을의 개수 N, 각 마을을 연결하는 도로의 정보 road, 음식 배달이 가능한 시간 K가 매개변수로 주어질 때, 음식 주문을 받을 수 있는 마을의 개수를 return 하도록 solution 함수를 완성해주세요.
road는 길이가 3인 배열이며, 순서대로 (a, b, c)를 나타냅니다.
N | road | K | result |
---|---|---|---|
5 | [[1,2,1],[2,3,3],[5,2,2],[1,4,2],[5,3,1],[5,4,2]] | 3 | 4 |
6 | [[1,2,1],[1,3,2],[2,3,2],[3,4,3],[3,5,2],[3,5,3],[5,6,1]] | 4 | 4 |
function solution(N, road, K) {
const MAX = 5000001
const answer = new Array(N+1).fill(0)
answer[1] = 1 // 1방
const ch = new Array(N+1).fill(0)
const dis = new Array(N+1).fill(MAX)
const map = new Array(N+1)
for (let i=0; i<=N; i++){
map[i] = new Array(N+1).fill(MAX)
}
for (let i=0; i<road.length; i++){
const [edge1, edge2, time] = road[i]
map[edge1][edge2] = Math.min(map[edge1][edge2], time)
map[edge2][edge1] = Math.min(map[edge2][edge1], time)
}
function DFS(L, sum){
if (sum > K) return
answer[L] = 1
for (let next=1; next<=N; next++){
if (!ch[next] || sum + map[L][next] < dis[next]){
ch[next] = 1
dis[next] = sum + map[L][next]
DFS(next, sum + map[L][next])
}
}
}
DFS(1, 0)
return answer.filter(v => v === 1).length
}