[백준] 1966
알고리즘2024. 4. 25. 11:59[백준] 1966

문제여러분도 알다시피 여러분의 프린터 기기는 여러분이 인쇄하고자 하는 문서를 인쇄 명령을 받은 ‘순서대로’, 즉 먼저 요청된 것을 먼저 인쇄한다. 여러 개의 문서가 쌓인다면 Queue 자료구조에 쌓여서 FIFO - First In First Out - 에 따라 인쇄가 되게 된다. 하지만 상근이는 새로운 프린터기 내부 소프트웨어를 개발하였는데, 이 프린터기는 다음과 같은 조건에 따라 인쇄를 하게 된다.1. 현재 Queue의 가장 앞에 있는 문서의 ‘중요도’를 확인한다.2. 나머지 문서들 중 현재 문서보다 중요도가 높은 문서가 하나라도 있다면, 이 문서를 인쇄하지 않고 Queue의 가장 뒤에 재배치한다. 그렇지 않다면 바로 인쇄를 한다.예를 들어 Queue에 4개의 문서(A B C D)가 있고, 중요도가 2..

[백준] 2164
알고리즘2024. 4. 24. 23:23[백준] 2164

문제N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다.이제 다음과 같은 동작을 카드가 한 장 남을 때까지 반복하게 된다. 우선, 제일 위에 있는 카드를 바닥에 버린다. 그 다음, 제일 위에 있는 카드를 제일 아래에 있는 카드 밑으로 옮긴다.예를 들어 N=4인 경우를 생각해 보자. 카드는 제일 위에서부터 1234 의 순서로 놓여있다. 1을 버리면 234가 남는다. 여기서 2를 제일 아래로 옮기면 342가 된다. 3을 버리면 42가 되고, 4를 밑으로 옮기면 24가 된다. 마지막으로 2를 버리고 나면, 남는 카드는 4가 된다.N이 주어졌을 때, 제일 마지막에 남게 되는 카드를 구하는 프로그..

Docker compose를 이용하여 DB 구축하기
Docker2024. 4. 24. 15:59Docker compose를 이용하여 DB 구축하기

Docker로 MySQL을 설치하고 사용하는 것에 이어서, 이번에는 docker-compose를 이용해서 DB를 구축해보았다. Docker compose란?다중 컨테이너 Docker 애플리케이션을 정의하고 실행하기 위한 도구이다.단일 YAML파일을 사용하여 여러 Docker 컨테이너를 단일 애플리케이션 스택으로 구성하고 관리할 수 있다.Docker compose를 사용하면 애플리케이션에 필요한 서비스, 네트워크, 볼륨 및 기타 구성을 정의할 수 있으므로복잡한 애플리케이션 환경을 쉽게 배포하고  관리할 수 있다. docker-compose.yml 파일 설정version: "3.8"services: db: image: mysql:8.0.28 restart: always ..

[백준] 10799
알고리즘2024. 4. 23. 11:43[백준] 10799

문제 여러 개의 쇠막대기를 레이저로 절단하려고 한다. 효율적인 작업을 위해서 쇠막대기를 아래에서 위로 겹쳐 놓고, 레이저를 위에서 수직으로 발사하여 쇠막대기들을 자른다. 쇠막대기와 레이저의 배치는 다음 조건을 만족한다. 쇠막대기는 자신보다 긴 쇠막대기 위에만 놓일 수 있다. 쇠막대기를 다른 쇠막대기 위에 놓는 경우 완전히 포함되도록 놓되, 끝점은 겹치지 않도록 놓는다. 각 쇠막대기를 자르는 레이저는 적어도 하나 존재한다. 레이저는 어떤 쇠막대기의 양 끝점과도 겹치지 않는다. 아래 그림은 위 조건을 만족하는 예를 보여준다. 수평으로 그려진 굵은 실선은 쇠막대기이고, 점은 레이저의 위치, 수직으로 그려진 점선 화살표는 레이저의 발사 방향이다. 이러한 레이저와 쇠막대기의 배치는 다음과 같이 괄호를 이용하여 왼..

[백준] 10773
알고리즘2024. 4. 22. 22:54[백준] 10773

문제 나코더 기장 재민이는 동아리 회식을 준비하기 위해서 장부를 관리하는 중이다. 재현이는 재민이를 도와서 돈을 관리하는 중인데, 애석하게도 항상 정신없는 재현이는 돈을 실수로 잘못 부르는 사고를 치기 일쑤였다. 재현이는 잘못된 수를 부를 때마다 0을 외쳐서, 가장 최근에 재민이가 쓴 수를 지우게 시킨다. 재민이는 이렇게 모든 수를 받아 적은 후 그 수의 합을 알고 싶어 한다. 재민이를 도와주자! 입력 첫 번째 줄에 정수 K가 주어진다. (1 ≤ K ≤ 100,000) 이후 K개의 줄에 정수가 1개씩 주어진다. 정수는 0에서 1,000,000 사이의 값을 가지며, 정수가 "0" 일 경우에는 가장 최근에 쓴 수를 지우고, 아닐 경우 해당 수를 쓴다. 정수가 "0"일 경우에 지울 수 있는 수가 있음을 보장할..

[묘공단] 2주차 학습 기록(스택, 큐)
알고리즘2024. 4. 22. 14:05[묘공단] 2주차 학습 기록(스택, 큐)

2주차에는 스택과 큐에 대해서 학습했습니다. 이 역시 많이 본 주제이기 때문에 다시 정리해보는 관점으로 공부했습니다. 스택(Stack) 스택의 어원은 '쌓는다'이다. 스택은 접시를 쌓는 것처럼 하나하나 쌓아올린 자료구조를 뜻한다. 스택의 특징 LIFO(후입선출)원칙을 따르는 선형 데이터구조이다. 접시 더미라고 생각하면, 최상단 접시만 꺼낼 수 있다. 작업 push: 스택의 맨 위에 항목을 추가 pop: 스택의 맨 위에서 항목을 제거하고 반환 peek or top: 항목을 제거하지 않고 스택 맨 위에 있는 항목을 반환 함수 호출, 역추적 알고리즘, 표현식 평가(중위 -> 후위), 실행 취소 메커니즘과 같은 곳에서 사용된다. 스택 사용 예시 자바에서 스택 자료구조를 사용한 예시이다. import java.u..

image