Learning JavaScript Data Structures and Algorithms 한국어판 [자바스크립트 자료 구조와 알고리즘]
- 원서명Learning JavaScript Data Structures and Algorithms (ISBN 9781783554874)
- 지은이로이아니 그로네르(Loiane Groner)
- 옮긴이이일웅
- ISBN : 9788960777842
- 25,000원
- 2015년 11월 19일 펴냄
- 페이퍼백 | 256쪽 | 188*235mm
- 시리즈 : acorn+PACKT, 웹 프로페셔널
책 소개
이 책의 예제 코드는 웹에서 실습해볼 수 있도록 JSFiddle에 게시해두었습니다. 여기에서 내려 받으세요.
요약
자료 구조와 알고리즘은 프로그래밍의 기본 중의 기본이지만, 처음 공부하는 사람에게는 결코 배우기가 만만치 않고 따분할 수 있는 과목이다. 이 책은 인터넷 브라우저만 있으면 곧바로 코드를 실행해볼 수 있게, 우리에게 친숙한 자바스크립트 언어를 사용해 딱딱하고 재미없는 자료 구조와 알고리즘 학습을 쉽고 명쾌하게 풀어준다.
이 책에서 다루는 내용
■ 배열, 스택, 큐에서 원소의 선언, 추가, 삭제
■ DFS와 BFS 알고리즘으로 가장 복잡한 자료 구조인 그래프를 만들어 사용
■ 연결 리스트, 이중 연결 리스트, 환형 연결 리스트의 강력한 쓰임새 이해
■ 해시 테이블, 딕셔너리, 집합으로 중복되지 않는 원소 저장
■ 이진 트리와 이진 탐색 트리의 응용
■ 버블 정렬, 선택 정렬, 삽입 정렬, 병합 정렬, 퀵 정렬 알고리즘을 이용한 자료 구조 정렬
■ 순차 탐색과 이진 탐색으로 자료 구조의 원소 찾기
■ O 표기법의 중요성과 동적 프로그래밍, 욕심쟁이 알고리즘 이해
이 책의 대상 독자
자바스크립트 개발자, 또는 자바스크립트의 기초 지식을 갖춘 사람이라면 자바스크립트의 최적화된 코드를 살펴보면서 빠르게 책장을 넘겨볼 수 있을 것이다. 알고리즘 공부를 재미있게 시작하려면 약간의 프로그래밍 지식은 필요하다.
이 책의 구성
1장, ‘자바스크립트 개요’에서는 자료 구조와 알고리즘을 배우기 전에 필요한 기본적인 내용과 이 책의 예제 코드 실습에 필요한 개발 환경 설정을 설명한다.
2장, ‘배열’에서는 자료 구조의 가장 기본이면서 많이 쓰이는 배열에 대해 다룬다. 배열의 원소를 선언, 초기화, 추가, 삭제하는 방법을 구체적인 예시로 설명하고, 자바스크립트 내장 메소드에 대해서도 알아본다.
3장, ‘스택’에서는 스택 자료 구조를 설명하고, 스택의 생성 방법과 원소를 추가/삭제하는 방법을 살펴본다. 스택을 이용해 컴퓨터 과학의 문제들을 어떻게 해결하는지 알아본다.
4장, ‘큐’에서는 큐 자료 구조를 설명하고, 큐의 생성 방법과 원소를 추가/삭제하는 방법을 살펴본다. 큐를 이용해 컴퓨터 과학의 문제들을 어떻게 해결하는지 알아보고, 스택과 큐의 차이점을 비교한다.
5장, ‘연결 리스트’에서는 객체와 포인터 개념을 가지고 연결 리스트 자료 구조를 만들어본다. 원소의 선언, 생성, 추가, 삭제하는 방법 외에도 이중 연결 리스트, 환형 연결 리스트 등의 변형된 형태의 연결 리스트에 대해서도 알아본다.
6장, ‘집합’에서는 집합 자료 구조를 소개하고, 비반복적인 원소를 저장하는 방법을 알아본다. 몇 가지 상이한 집합 연산에 대해 살펴보고 각각을 어떻게 구현할지, 어떻게 활용할지 배운다.
7장, ‘딕셔너리와 해시’에서는 딕셔너리, 해시 자료 구조와 둘 사이의 차이점을 설명한다. 두 자료 구조를 선언, 생성, 활용하고, 해시 충돌을 우회해 더 나은 해시 함수를 만드는 기법 등을 알아본다.
8장, ‘트리’에서는 트리 자료 구조와 관련 용어를 설명하고, 이진 탐색 트리와 노드를 탐색, 순회, 추가, 삭제하는 메소드를 집중적으로 다룬다. 흥미진진한 트리의 세계로 안내하고, 다음 단계에서 학습해야 할 트리 알고리즘을 제시한다.
9장, ‘그래프’에서는 놀라운 그래프 자료 구조의 세계로 여러분을 초대한다. 그래프를 응용해 실생활의 갖가지 문제들을 해결하는 방법과 일반적인 그래프 용어들, 그래프를 표현하는 여러 가지 방법, 너비 우선, 깊이 우선 탐색 알고리즘으로 그래프를 순회하는 방법과 응용 사례를 살펴본다.
10장, ‘정렬과 검색 알고리즘’에서는 가장 많이 쓰이는 정렬 알고리즘(버블 정렬, 선택 정렬, 삽입 정렬, 병합 정렬, 퀵 정렬)과 탐색 알고리즘(순차 검색, 이진 검색)을 다룬다.
11장, ‘그 밖의 알고리즘’에서는 몇몇 알고리즘을 추가로 소개하고 O 표기법의 개념을 설명한다. 재귀 개념을 비롯해서 동적 프로그래밍과 욕심쟁이 알고리즘 같은 고급 알고리즘 기법을 다룬다. 마지막으로, 여러분이 책거리를 한 이후에 공부할 내용을 제시한다.
부록, ’O 표기법 정리’에서는 이 책에서 배운 알고리즘의 복잡도를 O 표기법으로 정리한 표를 제공한다.
목차
목차
- 1 자바스크립트 개요
- 환경 세팅
- 브라우저 하나면 충분하다
- 웹 서버(XAMPP) 사용하기
- 순수 자바스크립트 환경(노드JS)
- 자바스크립트 기초
- 변수
- 변수 스코프
- 연산자
- Truthy와 Falsy
- 동등 연산자(= =/= = =)
- 변수
- 제어 구조
- 조건문
- 루프문
- 함수
- 객체지향 프로그래밍
- 디버깅 툴
- 정리
- 환경 세팅
- 2 배열
- 왜 배열을 사용하는가?
- 배열의 생성과 초기화
- 원소 추가와 삭제
- 2차원과 다차원 배열
- 자바스크립트 배열 메소드 정리
- 여러 배열 합치기
- 반복자 함수
- 검색과 정렬
- 사용자 정의 정렬
- 문자열 정렬
- 검색
- 배열을 문자열로 변환
- 정리
- 3 스택
- 스택 만들기
- 완성된 Stack 클래스
- Stack 클래스 사용
- 완성된 Stack 클래스
- 10진수에서 2진수로 변환
- 정리
- 스택 만들기
- 4 큐
- 큐 만들기
- 완성된 Queue 클래스
- Queue 클래스 사용
- 우선순위 큐
- 환형 큐(뜨거운 감자)
- 정리
- 큐 만들기
- 5 연결 리스트
- 연결 리스트 만들기
- 리스트 끝에 원소 추가하기
- 원소 삭제
- 임의의 위치에 원소 삽입하기
- 그 밖의 메소드 구현
- toString 메소드
- indexOf 메소드
- isEmpty, size, getHead 메소드
- 이중 연결 리스트
- 임의의 위치에 원소 삽입
- 원소 삭제
- 환형 연결 리스트
- 정리
- 연결 리스트 만들기
- 6 집합
- 집합 만들기
- has(원소) 메소드
- add 메소드
- remove와 clear 메소드
- size 메소드
- values 메소드
- Set 클래스 사용
- 집합 연산
- 합집합
- 교집합
- 차집합
- 부분집합
- 정리
- 집합 만들기
- 7 딕셔너리와 해시
- 딕셔너리
- 딕셔너리 만들기
- has와 set 메소드
- remove 메소드
- get과 values 메소드
- clear, size, keys, getItems 메소드
- 딕셔너리 클래스 사용
- 딕셔너리 만들기
- 해시 테이블
- 해시 테이블 만들기
- HasthTable 클래스 사용
- 해시 테이블과 해시 집합 비교
- 해시 테이블 간 충돌 해결
- 체이닝
- 선형 탐색법
- 해시 함수 개선
- 정리
- 딕셔너리
- 8 트리
- 트리 용어
- 이진 트리와 이진 탐색 트리
- BinarySearchTree 클래스 만들기
- 트리에 키 삽입하기
- 트리 순회
- 중위 순회
- 전위 순회
- 후위 순회
- 트리 노드 검색
- 최솟값/최댓값 찾기
- 특정 값 찾기
- 노드 삭제
- 리프 노드인 경우
- 좌/우측 어느 한쪽에만 자식 노드가 있는 경우
- 두 자식을 모두 가진 노드일 경우
- 이진 트리 보충 내용
- 정리
- 9 그래프
- 그래프 용어
- 방향/무방향 그래프
- 그래프 나타내기
- 인접 행렬
- 인접 리스트
- 근접 행렬
- Graph 클래스 만들기
- 그래프 순회
- 너비 우선 탐색(BFS)
- BFS로 최단 경로 찾기
- 최단 경로 알고리즘 관련 보충 내용
- 깊이 우선 탐색(DFS)
- DFS 알고리즘 탐구
- DFS를 이용한 위상 정렬
- 너비 우선 탐색(BFS)
- 정리
- 그래프 용어
- 10 정렬과 검색 알고리즘
- 정렬 알고리즘
- 버블 정렬
- 개선된 버블 정렬
- 선택 정렬
- 삽입 정렬
- 병합 정렬
- 퀵 정렬
- 파티션 과정
- 퀵 정렬 실행
- 버블 정렬
- 검색 알고리즘
- 순차 검색
- 이진 검색
- 정리
- 정렬 알고리즘
- 11 그 밖의 알고리즘
- 재귀
- 자바스크립트에서 호출 스택 크기의 한계
- 피보나치 수열
- 동적 프로그래밍
- 최소 동전 교환 문제
- 욕심쟁이 알고리즘
- 최소 동전 바꾸기 문제
- O 표기법
- O 표기법 이해
- O(1)
- O(n)
- O(n2)
- O 표기법 이해
- 알고리즘 복잡도 비교
- 재미있는 알고리즘의 세계로!
- 정리
- 재귀
- 부록 O 표기법 정리
- 자료 구조
- 그래프
- 정렬 알고리즘
- 검색 알고리즘
도서 오류 신고
정오표
정오표
[p.109 3행]
index = -1;
->
index = 0;