[프로그래머스 고득점 Kit] 스택/큐_다리를 지나는 트럭(level 2)

김예지·2021년 9월 28일
0

문제

*한번 이동할 때 시간이 얼마나 걸리는지 문제정의가 되어있지 않아서 문제 출처를 확인해보니, bridge length에서 한칸씩 이동할때마다, 1초가 소요된다고 되어있었다. (단위길이당 단위시간 이동)

트럭 여러 대가 강을 가로지르는 일차선 다리를 정해진 순으로 건너려 합니다. 모든 트럭이 다리를 건너려면 최소 몇 초가 걸리는지 알아내야 합니다. 다리에는 트럭이 최대 bridge_length대 올라갈 수 있으며, 다리는 weight 이하까지의 무게를 견딜 수 있습니다. 단, 다리에 완전히 오르지 않은 트럭의 무게는 무시합니다.

예를 들어, 트럭 2대가 올라갈 수 있고 무게를 10kg까지 견디는 다리가 있습니다. 무게가 [7, 4, 5, 6]kg인 트럭이 순서대로 최단 시간 안에 다리를 건너려면 다음과 같이 건너야 합니다.

따라서, 모든 트럭이 다리를 지나려면 최소 8초가 걸립니다.

solution 함수의 매개변수로 다리에 올라갈 수 있는 트럭 수 bridge_length, 다리가 견딜 수 있는 무게 weight, 트럭 별 무게 truck_weights가 주어집니다. 이때 모든 트럭이 다리를 건너려면 최소 몇 초가 걸리는지 return 하도록 solution 함수를 완성하세요.

[제한 조건]

  • bridge_length는 1 이상 10,000 이하입니다.
  • weight는 1 이상 10,000 이하입니다.
  • truck_weights의 길이는 1 이상 10,000 이하입니다.
  • 모든 트럭의 무게는 1이상 weight 이하입니다.

[입출력 예]


문제 풀이

코드1

테스트 케이스 5번의 시간이 300ms가 넘는다. 다른 방법을 사용해보자

function solution(bridge_length, weight, truck_weights) {
    var answer = 0;
    let queue=Array.from({length:bridge_length}, ()=>0);
    let queueSum=0;
    
    let truck=truck_weights.shift();
    queue.unshift(truck);
    queue.pop();
    queueSum+=truck;
    answer++;
    
    while(queueSum){
        queueSum-=queue.pop();
        truck=truck_weights.shift();
        
        if(truck+queueSum <= weight){
            queue.unshift(truck);
            queueSum+=truck;
        }
        else{
            queue.unshift(0);
            truck_weights.unshift(truck);

        }
        answer++;
        
    }
    return answer;
}

정리

  • 프로그래머스에 문제 정의가 제대로 되어있지 않아서 오랫동안 고민했던 문제다.
    한번 이동할 때 시간이 얼마나 걸리는지 문제정의가 되어있지 않아서 문제 출처를 확인해보니, bridge length에서 한칸씩 이동할때마다, 1초가 소요된다고 되어있었다. (단위길이당 단위시간 이동)
    그래서 대기→ 다리, 다리→다리(다음칸), 다리→끝 각각으로 이동할 때 1초씩 더해줘야한다.(이동할때마다 1초더해줘야하니까, answer++)

  • (코드1)if문도 순서가 중요하다!아래와 같은 문제가 생겼다.

    if(truck+queueSum > weight){
                queue.unshift(0);
                truck_weights.unshift(truck);
    }
    else{
                queue.unshift(truck);
                queueSum+=truck;
    
    }
    

    위처럼 했을때는 안됐는데,

    if(truck+queueSum <= weight){
                queue.unshift(truck);
                queueSum+=truck;
    }
    else{
                queue.unshift(0);
                truck_weights.unshift(truck);
    
    }

    이렇게 if, else 바꿨더니 되는 이유는 뭐지...?
    if문도 순서가 중요하다는 사실을 알게됐다. https://okky.kr/article/772610 를 참고하자! 제대로 코드를 친것같은데 결과값이 오답으로 나오면 if문의 순서를 고려해보자!

  • 테스트 케이스 5번의 시간이 300ms가 넘는다. 다른 방법을 사용해보자


참고

profile
내가 짱이다 😎 매일 조금씩 성장하기🌱

0개의 댓글