분류 전체보기
[ 백준 18405 해설 ] ( python ) 경쟁적 전염
📚 경쟁적 전염 문제 NxN 크기의 시험관이 있다. 시험관은 1x1 크기의 칸으로 나누어지며, 특정한 위치에는 바이러스가 존재할 수 있다. 모든 바이러스는 1번부터 K번까지의 바이러스 종류 중 하나에 속한다. 시험관에 존재하는 모든 바이러스는 1초마다 상, 하, 좌, 우의 방향으로 증식해 나간다. 단, 매 초마다 번호가 낮은 종류의 바이러스부터 먼저 증식한다. 또한 증식 과정에서 특정한 칸에 이미 어떠한 바이러스가 존재한다면, 그 곳에는 다른 바이러스가 들어갈 수 없다. 시험관의 크기와 바이러스의 위치 정보가 주어졌을 때, S초가 지난 후에 (X,Y)에 존재하는 바이러스의 종류를 출력하는 프로그램을 작성하시오. 만약 S초가 지난 후에 해당 위치에 바이러스가 존재하지 않는다면, 0을 출력한다. 이 때 X와..
[ 백준 14891 해설 ] ( python ) 톱니바퀴
📚 톱니바퀴 문제 총 8개의 톱니를 가지고 있는 톱니바퀴 4개가 아래 그림과 같이 일렬로 놓여져 있다. 또, 톱니는 N극 또는 S극 중 하나를 나타내고 있다. 톱니바퀴에는 번호가 매겨져 있는데, 가장 왼쪽 톱니바퀴가 1번, 그 오른쪽은 2번, 그 오른쪽은 3번, 가장 오른쪽 톱니바퀴는 4번이다. 이때, 톱니바퀴를 총 K번 회전시키려고 한다. 톱니바퀴의 회전은 한 칸을 기준으로 한다. 회전은 시계 방향과 반시계 방향이 있고, 아래 그림과 같이 회전한다. 톱니바퀴를 회전시키려면, 회전시킬 톱니바퀴와 회전시킬 방향을 결정해야 한다. 톱니바퀴가 회전할 때, 서로 맞닿은 극에 따라서 옆에 있는 톱니바퀴를 회전시킬 수도 있고, 회전시키지 않을 수도 있다. 톱니바퀴 A를 회전할 때, 그 옆에 있는 톱니바퀴 B와 서로..
[ 운영체제 ] 30분동안 안쉬고 설명하기 _ 기술노트 with 알렉
0. 기본 요소 이해하기 컴퓨터 구조에서 가장 핵심이 되는 요소 CPU가 있고 MEMORY, 이 내용들을 저장하는 Disk가 있다. 그리고 이것들을 화면으로 보여주는 디스플레이 장치(모니터) 입력할 수 있는 장치 입력(키보드) 가 기본 구조다 이런 CPU, Memory, Disk의 동작 원리 이런걸 배우는 것. CPU 내부에서 무슨 일이 일어나냐? 같은 내용을 배운다 이런 내용을 배우면(물리적인 동작 관련 내용을 배우면) 함께 동작하는 운영체제를 배운다. Disk의 내용이 Memory로 올라가고, 이 내용이 CPU에서 계산된다. 이렇게 운영시키는 것이 운영체제 window, renux unix같은 것이 있다. CUP나 메모리, disk만 있다고 해서 실행되는 것이 아니라, 이들은 다 운영체제 위에서 실행..
[ SNU 강의 ] 운영체제의 기초 | 쉽게 배우는 운영체제 1주차
0. 운영체제를 공부해야 하는 이유? CS의 여러 과목의 최고봉이다! 스마트폰, 자동차, 가전제품에서도 활용됨 다른 소프트웨어를 배우는 데에도 적용할 수 있음 📌 이 강좌에서 배울 것 OS가 제공하는 것들 기능과 내부구조 CS적인 이론이나 방법 결과적으로 OS의 내부 구성을 잘 알수 있다 ✍ OS의 진화과정 당시 컴퓨터 시스템을 운영하는 사람들의 목적은 비싼 하드웨어를 잘 활용하는 것 CPU의 utilization을 최대화하는 것 인건비는 상대적으로 저렴해 인건비는 고려하지 않음 사실 OS라는 것이 존재하지 않았음. 사람이 OS의 역할을 했음 사람이 오르골 펀칭뚫듯 입력을 하면 컴퓨터가 처리하는 원리 빛을 쏘인 다음에 그 패턴을 보고 값을 읽어드림 Operator의 역할 사용자로부터 카드 덱을 수령 카드..
[ 백준 14500 해설 ] ( python ) 테트로미노
📚 테트로미노 문제 폴리오미노란 크기가 1×1인 정사각형을 여러 개 이어서 붙인 도형이며, 다음과 같은 조건을 만족해야 한다. 정사각형은 서로 겹치면 안 된다. 도형은 모두 연결되어 있어야 한다. 정사각형의 변끼리 연결되어 있어야 한다. 즉, 꼭짓점과 꼭짓점만 맞닿아 있으면 안 된다. 정사각형 4개를 이어 붙인 폴리오미노는 테트로미노라고 하며, 다음과 같은 5가지가 있다. 아름이는 크기가 N×M인 종이 위에 테트로미노 하나를 놓으려고 한다. 종이는 1×1 크기의 칸으로 나누어져 있으며, 각각의 칸에는 정수가 하나 쓰여 있다. 테트로미노 하나를 적절히 놓아서 테트로미노가 놓인 칸에 쓰여 있는 수들의 합을 최대로 하는 프로그램을 작성하시오. 테트로미노는 반드시 한 정사각형이 정확히 하나의 칸을 포함하도록 놓..
[ 백준 3190 해설 ] ( python ) 뱀
📚 뱀 문제 'Dummy' 라는 도스게임이 있다. 이 게임에는 뱀이 나와서 기어다니는데, 사과를 먹으면 뱀 길이가 늘어난다. 뱀이 이리저리 기어다니다가 벽 또는 자기자신의 몸과 부딪히면 게임이 끝난다. 게임은 NxN 정사각 보드위에서 진행되고, 몇몇 칸에는 사과가 놓여져 있다. 보드의 상하좌우 끝에 벽이 있다. 게임이 시작할때 뱀은 맨위 맨좌측에 위치하고 뱀의 길이는 1 이다. 뱀은 처음에 오른쪽을 향한다. 뱀은 매 초마다 이동을 하는데 다음과 같은 규칙을 따른다. 먼저 뱀은 몸길이를 늘려 머리를 다음칸에 위치시킨다. 만약 이동한 칸에 사과가 있다면, 그 칸에 있던 사과가 없어지고 꼬리는 움직이지 않는다. 만약 이동한 칸에 사과가 없다면, 몸길이를 줄여서 꼬리가 위치한 칸을 비워준다. 즉, 몸길이는 변하..
[ 백준 11403 해설 ] ( python ) 경로 찾기
📚 경로 찾기 문제 가중치 없는 방향 그래프 G가 주어졌을 때, 모든 정점 (i, j)에 대해서, i에서 j로 가는 경로가 있는지 없는지 구하는 프로그램을 작성하시오. 입력 첫째 줄에 정점의 개수 N (1 ≤ N ≤ 100)이 주어진다. 둘째 줄부터 N개 줄에는 그래프의 인접 행렬이 주어진다. i번째 줄의 j번째 숫자가 1인 경우에는 i에서 j로 가는 간선이 존재한다는 뜻이고, 0인 경우는 없다는 뜻이다. i번째 줄의 i번째 숫자는 항상 0이다. 출력 총 N개의 줄에 걸쳐서 문제의 정답을 인접행렬 형식으로 출력한다. 정점 i에서 j로 가는 경로가 있으면 i번째 줄의 j번째 숫자를 1로, 없으면 0으로 출력해야 한다. 예제 입력 1 복사 3 0 1 0 0 0 1 1 0 0 예제 출력 1 복사 1 1 1 1..
[ 백준 16236 해설 ] ( python ) 아기 상어
📚 아기 상어 문제 N×N 크기의 공간에 물고기 M마리와 아기 상어 1마리가 있다. 공간은 1×1 크기의 정사각형 칸으로 나누어져 있다. 한 칸에는 물고기가 최대 1마리 존재한다. 아기 상어와 물고기는 모두 크기를 가지고 있고, 이 크기는 자연수이다. 가장 처음에 아기 상어의 크기는 2이고, 아기 상어는 1초에 상하좌우로 인접한 한 칸씩 이동한다. 아기 상어는 자신의 크기보다 큰 물고기가 있는 칸은 지나갈 수 없고, 나머지 칸은 모두 지나갈 수 있다. 아기 상어는 자신의 크기보다 작은 물고기만 먹을 수 있다. 따라서, 크기가 같은 물고기는 먹을 수 없지만, 그 물고기가 있는 칸은 지나갈 수 있다. 아기 상어가 어디로 이동할지 결정하는 방법은 아래와 같다. 더 이상 먹을 수 있는 물고기가 공간에 없다면 아..