R 데이터 구조와 알고리즘 [효율적인 데이터 구조와 알고리즘으로 애플리케이션의 속도와 성능을 높이자]
- 원서명R Data Structures and Algorithms (ISBN 9781786465153)
- 지은이PKS 프라카시(PKS Prakash), 아슈튜니 스리 크리슈나 라오(Achyutuni Sri Krishna Rao)
- 옮긴이김우현
- ISBN : 9791161750200
- 30,000원
- 2017년 07월 07일 펴냄
- 페이퍼백 | 316쪽 | 188*235mm
- 시리즈 : acorn+PACKT
책 소개
소스 코드 파일은 여기에서 내려 받으실 수 있습니다.
본문에 쓰인 컬러 이미지는 여기에서 내려 받으세요.
요약
아홉 가지 정렬 알고리즘의 장단점, 스택과 큐를 배열로 구현했을 때와 링크드 리스트로 구현했을 때의 차이점 등을 R 사용자들이 쉽게 이해할 수 있도록 설명한다. 여러 가지 인덱싱 구조와 함께 최신 기술인 그래프 데이터 구조를 다루며, 현대적인 프로그래밍 기법인 무작위 알고리즘과 함수형 데이터 구조에 대해서도 설명한다. R 사용자가 아니더라도 다양한 알고리즘과 데이터 구조의 상호작용에 대해 관심이 있다면 이 책을 통해 쉽게 접근할 수 있을 것이다.
이 책에서 다루는 내용
■ 데이터 구조와 알고리즘의 합리성 이해
■ 프로그램의 연산 능력을 특징짓는 알고리즘의 점근 분석 및 경험적 분석 이해
■ 배열 기반 및 링크드 리스트 기반 데이터 구조의 기초 지식
■ 정렬 알고리즘 분석
■ 해싱과 검색 알고리즘
■ 선형 인덱싱 및 트리 기반 인덱싱 이해
■ 위상 정렬, 최단 거리 문제, 그리고 프림 알고리즘을 포함한 그래프 구현
■ 동적 계획법(배낭 문제)과 무작위 알고리즘 이해
이 책의 대상 독자
이 책은 데이터 구조를 효율적으로 사용하고자 하는 R 개발자를 위한 것이다. R에 대한 기본 지식을 알고 있어야 한다.
이 책의 구성
1장, ‘시작하기’에서는 R 기초 수립에 중요한 데이터 구조 관련 배경 지식과 그 중요성을 알아본다.
2장, ‘알고리즘 분석’에서는 알고리즘 분석을 위한 동기 부여, 기본 표기법, 기초적인 기법에 대해 설명한다.
3장, ‘링크드 리스트’에서는 링크드 리스트의 기초를 세우고, 선형 링크드 리스트, 이중 링크드 리스트, 원형 링크드 리스트 등과 같은 링크드 리스트의 다양한 형태를 알아본다.
4장, ‘스택과 큐’에서는 배열과 링크드 리스트 기반의 스택과 큐를 소개하고 R에서 구현해본다.
5장, ‘정렬 알고리즘’에서는 삽입 정렬, 버블 정렬, 선택 정렬, 쉘 정렬 등 다양한 정렬 알고리즘에 대해 설명하고, 서로 다른 알고리즘을 비교해서 보여준다.
6장, ‘검색 옵션 탐색’에서는 벡터 및 링크드 리스트를 포함한 리스트에 대한 검색 처리에 대해 상세히 알아본다. 또한, 자기조직화 리스트와 해시 개념도 살펴본다.
7장, ‘인덱싱’에서는 디스크에서 파일을 구조화하고 대용량의 데이터를 체계화하는 데 핵심적인 인덱싱 개념을 설명한다. ISAM, 2-3 트리, B-트리, B+ 트리 등을 자세히 살펴본다.
8장, ‘그래프’에서는 그래프 데이터 구조 및 구현을 위한 기초를 정립한다. 또한, 순회, 최단 경로 문제, 최소 비용 신장 트리 알고리즘에 대해서도 알아본다.
9장, ‘프로그래밍과 무작위 알고리즘’에서는 정적인 데이터 구조에서 무작위 스킵 리스트와 같은 무작위 데이터 구조로 개념을 확장해 살펴본다. 또한, 프로그래밍 개념과 여러 가지 애플리케이션을 학습한다.
10장, ‘함수형 데이터 구조’에서는 함수형 데이터 구조와 지연된 평가에 대해 소개한다. 그리고 R에서 함수형 스택과 함수형 큐를 다룬다.
목차
목차
- 1장. 시작하기
- 데이터 구조 소개
- 추상 데이터 타입과 데이터 구조
- 문제와 알고리즘과의 관계
- R 기초
- R 설치
- R의 기본 데이터 구조
- R의 연산자
- R의 제어문
- If 조건문
- If...else 조건문
- Ifelse 함수
- for 루프
- 중첩 for 루프
- While 루프
- 루프 내에서 사용하는 특수한 명령문
- 반복 루프
- R의 1등급 함수
- 연습문제
- 요약
- 2장. 알고리즘 분석
- 데이터 구조로 시작하기
- R에서의 메모리 관리
- R에서의 시스템 런타임
- 최선, 최악, 평균적인 경우
- 컴퓨터 vs. 알고리즘
- 알고리즘 점근 분석
- 상한 또는 빅 오 표기법
- 하한 또는 빅 오메가 표기법
- 빅 세타 표기법
- 단순화 규칙
- 분류 규칙
- 프로그램의 계산능력 추정
- 요소 1 - 할당 연산자
- 요소 2 - 단순 루프
- 요소 3 - 복잡한 루프
- 요소 4 - 조건문을 가진 루프
- 요소 5 - 재귀 명령문
- 문제 분석
- 공간 한계
- 연습문제
- 요약
- 3장. 링크드 리스트
- R의 데이터 타입
- 벡터와 원자 벡터
- 요소 데이터 타입
- 팩터
- 매트릭스
- 배열
- 데이터 프레임
- 리스트
- R에서의 객체지향 프로그래밍
- 링크드 리스트
- 선형 링크드 리스트
- 이중 링크드 리스트
- 원형 링크드 리스트
- 배열 기반 리스트
- 리스트 작업 분석
- 연습문제
- 요약
- R의 데이터 타입
- 4장. 스택과 큐
- 스택
- 배열 기반 스택
- 링크드 스택
- 배열 기반 스택과 링크드 리스트 기반 스택 비교
- 재귀 함수 구현
- 큐
- 배열 기반 큐
- 링크드 큐
- 배열 기반 큐와 링크드 리스트 기반 큐 비교
- 딕셔너리
- 연습문제
- 요약
- 스택
- 5장. 정렬 알고리즘
- 정렬 관련 용어와 표기법
- 세 가지 Θ(n²) 정렬 알고리즘
- 삽입 정렬
- 버블 정렬
- 선택 정렬
- 교환 정렬의 비용
- 셸 정렬
- 병합 정렬
- 퀵 정렬
- 힙 정렬
- 버킷 정렬과 기수 정렬
- 정렬 알고리즘의 경험적인 비교
- 정렬의 하한
- 연습문제
- 요약
- 6장. 검색 옵션 탐색
- 정렬되지 않은 벡터와 정렬된 벡터에 대한 검색
- 자기조직화 리스트
- 휴리스틱 1 - 카운트
- 휴리스틱 2 - 전진이동
- 휴리스틱 3 - 전치
- 해싱
- 해시 함수
- 오픈 해싱
- 클로즈드 해싱
- 버킷 해싱
- 선형 탐사
- 클로즈드 해싱 분석
- 삭제
- 연습문제
- 요약
- 7장. 인덱싱
- 선형 인덱싱
- ISAM
- 트리 기반 인덱싱
- 2-3 트리
- B-트리
- B+ 트리
- B-트리 분석
- 연습문제
- 요약
- 8장. 그래프
- 용어와 표현들
- 그래프 구현
- 그래프 순회
- 깊이 우선 탐색
- 너비 우선 탐색
- 위상 정렬
- 최단 경로 문제
- 단일 소스 최단 경로
- 최소 비용 신장 트리
- 프림 알고리즘
- 크루스칼 알고리즘
- 연습문제
- 요약
- 9장. 프로그래밍과 무작위 알고리즘
- 동적 계획법
- 배낭 문제
- 모든 쌍 최단 경로
- 무작위 알고리즘
- 큰 값을 찾기 위한 무작위 알고리즘
- 스킵 리스트
- 스킵 리스트의 확률론적 분석
- 연습문제
- 요약
- 동적 계획법
- 10장. 함수형 데이터 구조
- 함수형 데이터 구조
- 지연된 평가
- 함수형 스택
- 함수형 큐
- 빠른 완전 지속성 큐
- 느린 지속성 큐와 양방향 큐
- 요약
- 함수형 데이터 구조