[프로그래머스] 택배상자

2024. 10. 2. 23:27·PS/프로그래머스
반응형

문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

입력

order:[Int] = 택배 트럭에 실어야하는 순서

결과

ans: Int = 원하는 순서로 실을 수 있는 최대 상자

해석

현재 컨베이어 벨트에 있는 순서는 항상 [1...n] 순으로 있고 앞에서부터 뺄 수 있다.

이후 택배 트럭에 실어야할 순서인 상자가 아니면 stack에 임시로 넣고 아니면 바로 뺀다.

 

정리하면 택배 상자를 내릴 수 있는 경우의 수는 2가지다.

  • 컨베이어 벨트에서 뺀다.
  • 스택에서 뺀다. 단, 스택은 가장 최근에 실은 순으로 뺄 수 있다.

코드

import Foundation

func solution(_ order:[Int]) -> Int {
    let n = order.count
    var priority: [Int] = [Int](repeating: 0, count: n) // 우선순위
    
    for i in 0..<n {
        priority[order[i]-1] = i
    }
    
    var target: Int = 0 // 현재 꺼내야하는 우선순위
    var stack: [Int] = []
    
    for i in 0..<n {
        if target == priority[i] { // 현재 target과 i의 우선순위가 같다면
            target += 1 
        } else {
            stack.append(priority[i]) // 아니면 스택
        }
        
         while !stack.isEmpty && stack.last! == target {
                let _ = stack.popLast()
                target += 1
        }
        
    }
    
    return target 
}

 

반응형

'PS > 프로그래머스' 카테고리의 다른 글

[프로그래머스] 무인도 여행  (4) 2024.10.04
[프로그래머스] 미로 탈출  (1) 2024.10.04
[프로그래머스] n + 1 카드게임  (0) 2024.10.01
[프로그래머스] 산 모양 타일링  (0) 2024.10.01
[프로그래머스] 미로 탈출 명령어  (1) 2024.09.30
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 무인도 여행
  • [프로그래머스] 미로 탈출
  • [프로그래머스] n + 1 카드게임
  • [프로그래머스] 산 모양 타일링
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (339)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (21)
        • 이론 (10)
        • MCP (1)
        • LangGraph (10)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    UIKit
    dispatch
    CS
    concurrency
    Swift
    protocol
    Tuist
    dp
    GIT
    property
    lifecycle
    AVFoundation
    boostcamp
    Spring
    SwiftUI
    프로그래머스
    백준
    dfs
    투포인터
    IOS
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 택배상자
상단으로

티스토리툴바