일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 데이터베이스
- 인프콘2024
- 수학
- 코테
- Python
- db
- mongoDB
- chatGPT
- Algorithm
- 그래프
- 알고리즘
- 파이썬
- 그리디알고리즘
- 알고리즘기초
- 기초
- 마크다운문법
- 코딩테스트
- Markdown
- 백준
- database
- httpCode
- 소수
- 코딩문제
- 수열
- 데이터
- NoSQL
- 탐색알고리즘
- 그리디
- 마크다운
- 몽고DB
- Today
- Total
목록전체 글 (52)
Dev_from the Bottom
DFS : Depth-First-Search 깊이 우선 탐색 그래프에서 깊은 부분을 우선적으로 탐색하는 알고리즘 특정한 경로로 탐색하다가 특정한 상황에서 최대한 깊숙이 들어가서 노드를 방문한 후, 다시 돌아가 다른 경로로 탐색하는 알고리즘 동작 과정 1) 탐색 시작 노드를 스택에 삽입하고 방문 처리를 한다. 2) 스택의 최상단 노드에 방문하지 않은 인접 노드가 있으면, 그 인접 노드를 스택에 넣고 방문 처리를 한다. 방문하지 않은 인접 노드가 없으면 스택에서 최상단 노드를 꺼낸다. 3) 2번의 과정을 더 이상 수행할 수 없을 때까지 반복한다. * 방문 처리 : 스택에 한 번 삽입되어 처리된 노드가 다시 삽입되지 않게 체크하는 것을 의미. 방문 처리를 함으로써 각 노드를 한 번씩만 처리 가능 ** DFS의..
DFS, BFS를 공부하기 전에 먼저 그래프(Graph)의 기본 구조를 알아야 함 그래프(Graph)의 기본 구조 그래프는 노드(Node)와 간선(Edge)로 표현됨 Node를 정점(Vertex)라고도 함 그래프 탐색 : 하나의 노드를 시작으로 다수의 노드를 방문하는 것 두 노드가 간선으로 연결되어 있다면, '두 노드는 인접하다(Adjacent)'라고 표현 '노드 : 도시, 간선 : 도로' 로 이해할 수 있음 Edge는 거리로 표현할 수 있는 '비용'을 갖을 수 있다. 인접 행렬, 인접 리스트 프로그래밍에서 그래프는 크게 2가지 방식으로 표현될 수 있음 1) 인접 행렬(Adjacency Matrix) : 2차원 배열로 그래프의 연결 관계를 표현하는 방식 2) 인접 리스트(Adjacency List) : ..
문제) 단어의 개수 - 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다. 입력) - 첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다. 출력) - 첫째 줄에 단어의 개수를 출력한다. 문제 링크) https://www.acmicpc.net/problem/1152 Step1) 테스트1 str = 'The Curious Case of Benjamin Button' list = str..
DFS, BFS를 이해하기 위해서는 기본 자료구조인 스택과 큐를 이해해야 하고, 재귀 함수를 알아야 한다. 1. Stack Stack는 박스 쌓기에 비유할 수 있음 선입후출(First In Last Out) or 후입선출(Last In First Out) 파이썬에서 스택을 이용할 때에는 별도의 라이브러리를 사용할 필요가 없음 기본 리스트에서 append()와 pop() 메서드를 이용하면 스택 자료구조와 동일하게 동작 append()메서드는 리스트의 가장 뒤쪽에 데이터를 삽입하고, pop() 메서드는 리스트의 가장 뒤쪽에서 데이터를 꺼냄 stack = [] stack.append(5) stack.append(2) stack.append(3) stack.append(7) stack.pop() stack.ap..