일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 | 31 |
- 우아한테크코스
- dfs
- 프리코스
- 최단거리
- Sort
- 그래프
- 그리디
- npm
- 코딩테스트
- 웹개발
- Python
- 고득점kit
- 알고리즘
- 프론트엔드
- 코테
- node.js
- express
- Linux
- 백준
- BFS
- OpenCV
- 우테코
- 문자열
- 프로그래머스
- 자바스크립트
- 함수
- JS
- JavaScript
- JetsonNano
- 파이썬
- Today
- Total
목록스터디/백준 (18)
공대생

문제설명 오늘도 서준이는 깊이 우선 탐색(DFS) 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자. N개의 정점과 M개의 간선으로 구성된 무방향 그래프(undirected graph)가 주어진다. 정점 번호는 1번부터 N번이고 모든 간선의 가중치는 1이다. 정점 R에서 시작하여 깊이 우선 탐색으로 노드를 방문할 경우 노드의 방문 순서를 출력하자. 깊이 우선 탐색 의사 코드는 다음과 같다. 인접 정점은 오름차순으로 방문한다. dfs(V, E, R) { # V : 정점 집합, E : 간선 집합, R : 시작 정점 visited[R]

문제설명 그래프를 DFS로 탐색한 결과와 BFS로 탐색한 결과를 출력하는 프로그램을 작성하시오. 단, 방문할 수 있는 정점이 여러 개인 경우에는 정점 번호가 작은 것을 먼저 방문하고, 더 이상 방문할 수 있는 점이 없는 경우 종료한다. 정점 번호는 1번부터 N번까지이다. 제한사항 N(1 ≤ N ≤ 1,000) M(1 ≤ M ≤ 10,000) 입력 첫째 줄에 정점의 개수 N(1 ≤ N ≤ 1,000), 간선의 개수 M(1 ≤ M ≤ 10,000), 탐색을 시작할 정점의 번호 V가 주어진다. 다음 M개의 줄에는 간선이 연결하는 두 정점의 번호가 주어진다. 어떤 두 정점 사이에 여러 개의 간선이 있을 수 있다. 입력으로 주어지는 간선은 양방향이다. 출력 첫째 줄에 DFS를 수행한 결과를, 그 다음 줄에는 BF..

문제설명 수빈이는 TV를 보고 있다. 수빈이는 채널을 돌리려고 했지만, 버튼을 너무 세게 누르는 바람에, 일부 숫자 버튼이 고장났다. 리모컨에는 버튼이 0부터 9까지 숫자, +와 -가 있다. +를 누르면 현재 보고있는 채널에서 +1된 채널로 이동하고, -를 누르면 -1된 채널로 이동한다. 채널 0에서 -를 누른 경우에는 채널이 변하지 않고, 채널은 무한대 만큼 있다. 수빈이가 지금 이동하려고 하는 채널은 N이다. 어떤 버튼이 고장났는지 주어졌을 때, 채널 N으로 이동하기 위해서 버튼을 최소 몇 번 눌러야하는지 구하는 프로그램을 작성하시오. 수빈이가 지금 보고 있는 채널은 100번이다. 제한사항 입력 첫째 줄에 수빈이가 이동하려고 하는 채널 N (0 ≤ N ≤ 500,000)이 주어진다. 둘째 줄에는 고장..

문제설명 한수는 크기가 2^N × 2^N인 2차원 배열을 Z모양으로 탐색하려고 한다. 예를 들어, 2×2배열을 왼쪽 위칸, 오른쪽 위칸, 왼쪽 아래칸, 오른쪽 아래칸 순서대로 방문하면 Z모양이다. N > 1인 경우, 배열을 크기가 2^(N-1) × 2^(N-1)로 4등분 한 후에 재귀적으로 순서대로 방문한다. 다음 예는 2^2 × 2^2 크기의 배열을 방문한 순서이다. N이 주어졌을 때, r행 c열을 몇 번째로 방문하는지 출력하는 프로그램을 작성하시오. 다음은 N=3일 때의 예이다. 제한사항 1 ≤ N ≤ 15 0 ≤ r, c N > 1인 경우, 배열을 크기가 2^..

문제설명 차세대 영농인 한나는 강원도 고랭지에서 유기농 배추를 재배하기로 하였다. 농약을 쓰지 않고 배추를 재배하려면 배추를 해충으로부터 보호하는 것이 중요하기 때문에, 한나는 해충 방지에 효과적인 배추흰지렁이를 구입하기로 결심한다. 이 지렁이는 배추근처에 서식하며 해충을 잡아 먹음으로써 배추를 보호한다. 특히, 어떤 배추에 배추흰지렁이가 한 마리라도 살고 있으면 이 지렁이는 인접한 다른 배추로 이동할 수 있어, 그 배추들 역시 해충으로부터 보호받을 수 있다. 한 배추의 상하좌우 네 방향에 다른 배추가 위치한 경우에 서로 인접해있는 것이다. 한나가 배추를 재배하는 땅은 고르지 못해서 배추를 군데군데 심어 놓았다. 배추들이 모여있는 곳에는 배추흰지렁이가 한 마리만 있으면 되므로 서로 인접해있는 배추들이 몇..

문제설명 팀 레드시프트는 대회 준비를 하다가 지루해져서 샌드박스 게임인 ‘마인크래프트’를 켰다. 마인크래프트는 1 × 1 × 1(세로, 가로, 높이) 크기의 블록들로 이루어진 3차원 세계에서 자유롭게 땅을 파거나 집을 지을 수 있는 게임이다. 목재를 충분히 모은 lvalue는 집을 짓기로 하였다. 하지만 고르지 않은 땅에는 집을 지을 수 없기 때문에 땅의 높이를 모두 동일하게 만드는 ‘땅 고르기’ 작업을 해야 한다. lvalue는 세로 N, 가로 M 크기의 집터를 골랐다. 집터 맨 왼쪽 위의 좌표는 (0, 0)이다. 우리의 목적은 이 집터 내의 땅의 높이를 일정하게 바꾸는 것이다. 우리는 다음과 같은 두 종류의 작업을 할 수 있다. 좌표 (i, j)의 가장 위에 있는 블록을 제거하여 인벤토리에 넣는다. ..

11401 - 이항 계수 3 이항계수를 계산하는 공식은 아래와 같다. 이 문제에서 우리가 구하려는 것은 해당 조합 값을 P(1000000007)로 나눈 나머지이다. 무턱대고 위의 공식을 이용해 이항계수를 구하고 P로 나눈 나머지를 출력하면 당연하게도 시간초과가 뜬다. 큰 수를 계산할 때 시간이 걸린다는 이유로 이런 식으로 식을 풀게되면 분모가 0이 되는 경우가 있어서 런타임에러(/ by zero) 가 뜨게된다. 따라서 해당식을 분수형태가 아닌 정수의 곱으로 표현해야할 필요가 있다. 이때 필요한 게 페르마의 소정리이다. 페르마의 소정리 p가 소수이고 a가 정수일 때, 다음을 만족한다는 것이다. a^p와 a가 합동이라고 하는데 정수론에서는 p로 나눈 나머지가 동일하다는 뜻으로 쓰인다. ( 예를 들어 5^3과..
문제 접근 순서 1. 문자열 받기 2. 다이얼 한수 만들기 3. 초 세기 알게 된 점 (1) 파이썬에서 '또는' 연산자는 'or'이다. 다른 언어에서 쓰던 것처럼 자꾸 '||'를 써서 문법오류남 (2) 파이썬에서 else if는 elif다. 최종제출답안 s = input() def dial(N): if(N == 'A' or N == 'B' or N == 'C'): return 3 elif(N == 'D' or N == 'E' or N == 'F'): return 4 elif(N == 'G' or N == 'H' or N == 'I'): return 5 elif(N == 'J' or N == 'K' or N == 'L'): return 6 elif(N == 'M' or N == 'N' or N == 'O'..