Python-DS 소개
데이터 구조 개요
데이터 구조는 모든 언어로 효율적인 프로그램을 작성하는 데 도움이되는 컴퓨터 과학의 기본 개념입니다. Python은 다른 프로그래밍 언어에 비해 더 간단한 방법으로 데이터 구조의 기초를 연구 할 수있는 고수준의 해석 된 대화 형 객체 지향 스크립팅 언어입니다.
이 장에서 우리는 일반적으로 자주 사용되는 데이터 구조에 대한 간략한 개요와 특정 파이썬 데이터 유형과 관련되는 방법을 연구 할 것입니다. 또 다른 범주로 나열된 파이썬에 특정한 데이터 구조도 있습니다.
일반 데이터 구조
컴퓨터 과학의 다양한 데이터 구조는 크게 아래에 표시된 두 가지 범주로 나뉩니다. 다음 장에서 아래의 각 데이터 구조에 대해 자세히 설명합니다.
라이너 데이터 구조
이들은 순차적 인 방식으로 데이터 요소를 저장하는 데이터 구조입니다.
- Array: 데이터 요소의 인덱스와 쌍을 이루는 데이터 요소의 순차적 배열입니다.
- Linked List: 각 데이터 요소는 그 안에있는 데이터와 함께 다른 요소에 대한 링크를 포함합니다.
- Stack: 특정 작업 순서 만 따르는 데이터 구조입니다. LIFO (선입 선출) 또는 FILO (선입 선출).
- Queue: Stack과 비슷하지만 동작 순서는 FIFO (First In First Out)뿐입니다.
- Matrix: 데이터 요소가 한 쌍의 인덱스에 의해 참조되는 2 차원 데이터 구조입니다.
비선형 데이터 구조
이들은 데이터 요소의 순차 연결이없는 데이터 구조입니다. 데이터 요소 쌍 또는 그룹은 서로 연결될 수 있으며 엄격한 순서없이 액세스 할 수 있습니다.
- Binary Tree: 각 데이터 요소가 최대 두 개의 다른 데이터 요소에 연결될 수 있고 루트 노드로 시작하는 데이터 구조입니다.
- Heap: 부모 노드의 데이터가 자식 노드보다 엄격하게 크거나 같거나 자식 노드보다 엄격하게 작은 트리 데이터 구조의 특별한 경우입니다.
- Hash Table: 해시 함수를 사용하여 서로 연결된 배열로 구성된 데이터 구조입니다. 데이터 요소의 색인이 아닌 키를 사용하여 값을 검색합니다.
- Graph: .일부 노드가 링크를 통해 서로 연결되는 정점과 노드의 배열입니다.
Python 특정 데이터 구조
이러한 데이터 구조는 Python 언어에 고유하며 다양한 유형의 데이터를 저장할 때 더 큰 유연성과 Python 환경에서 더 빠른 처리를 제공합니다.
- List: 데이터 요소가 다른 데이터 유형일 수 있다는 점을 제외하면 배열과 유사합니다. 파이썬 목록에 숫자 및 문자열 데이터를 모두 포함 할 수 있습니다.
- Tuple: 튜플은 목록과 유사하지만 불변이므로 튜플의 값은 수정할 수 없으며 읽기만 가능합니다.
- Dictionary: 사전에는 데이터 요소로 키-값 쌍이 포함됩니다.
다음 장에서는 이러한 각 데이터 구조를 Python을 사용하여 구현하는 방법에 대해 자세히 알아볼 것입니다.