Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 2870번 수학숙제
- Algorithm
- 백준
- 코테
- 수학숙제
- 백준 1103번
- 17070번
- 백준 1103번 게임
- 백준 17070번
- 유니티
- Beakjoon
- 코딩테스트
- Unity
- 플레이어 이동
- Lv2
- 2870번 수학숙제 c++
- Lv.3
- 2870번 c++
- 백준 c++ 2468번
- C#
- 백준 17070번 c++
- 2468 c++
- 백준 2870번
- 프로그래머스
- 2870번
- 백준 c++ 2870번
- dfs
- c++
- 오브젝트 풀링
- 백준 1103번 c++
Archives
- Today
- Total
주녘공부일지
[프로그래머스 C#] Lv.2 택배상자 본문
https://school.programmers.co.kr/learn/courses/30/lessons/131704#
1. 정답코드 및 핵심 아이디어, 유의사항
이해만 잘 한다면 굉장히 직관적인 문제로, 문제를 잘 이해하는 것이 중요함
- 주어진 order는 순서대로 넣어야 하는 순서임
- 보조 컨테이너 벨트는 stack과 동일한 동작을 함 ( 후입선출 )
- 택배 상자는 1번부터 순서대로 n개가 존재하고 순서대로 뺴올 수 있음 ( 마치 queue처럼 )
-> 빼온 택배 상자는 order에 맞으면 넣고, 아니면 보조 컨테이너 벨트(stack)에 넣어야 함
-> 이 때, 만약 보조 컨테이너 벨트에서 컨테이너 벨트로 넣을 수 있다면 넣고 다시 확인
( 컨테이너 벨트에 넣어야 할 번호가 갱신되므로 )
주석 참조
using System;
using System.Collections.Generic;
public class Solution
{
public int solution(int[] order)
{
int answer = 0; // order[answer] : 컨테이너 벨트에 실어야 할 번호
var stack = new Stack<int>(); // 보조 컨테이너 벨트
// 1번 ~ 마지막 택배 상자까지 컨테이너 벨트 or 보조 컨테이너 벨트에 담음
for (int i = 1; i <= order.Length; i++)
{
if (i == order[answer])
{
// 컨테이너 벨트에 넣음
answer++;
}
else if (stack.Count > 0 && stack.Peek() == order[answer])
{
// 보조 컨테이너 벨트 -> 컨테이너 벨트
stack.Pop();
answer++;
i--;
}
else
{
// 보조 컨테이너 벨트에 넣음
stack.Push(i);
}
}
// 보조 컨테이너 벨트 -> 컨테이너 벨트로 넣을 수 있다면 계속 넣음
while (stack.Count > 0 && stack.Peek() == order[answer])
{
answer++;
stack.Pop();
}
return answer;
}
}
'CodingTest > Programmers Lv.2' 카테고리의 다른 글
[프로그래머스 C#] Lv.2 도넛과 막대 그래프 (0) | 2024.01.05 |
---|---|
[프로그래머스 C#] Lv.2 거리두기 확인하기 (0) | 2023.12.30 |
[프로그래머스 C#] Lv.2 광물 캐기 (0) | 2023.12.29 |
[프로그래머스 C#] Lv.2 미로 탈출 (1) | 2023.12.27 |
[프로그래머스 C#] Lv.2 택배 배달과 수거하기 (0) | 2023.12.25 |