컴퓨터언어/자료구조&알고리즘(15)
-
[Stack] Linked List로 구현하기 2020.06.03
-
[Double Linked List] JS로 구현하기 2020.05.28
-
[Linked List] JS로 구현하기 2020.05.28
-
[Hash Table] 배열과 달리 비연속적인 공간에 데이터를 저장
배열이 데이터를 메모리에 연속으로 따닥따닥 보관했다면, 해시테이블은 메모리 이곳저곳에 랜덤으로 자료를 보관한다. 해시테이블은 언어에 따라 명칭이 다르지만, 모두 가지고 있는 중요한 자료구조다. 해시테이블은 key-value 쌍으로 이루어져 있는데, 여기서의 key는 배열에서 숫자 인덱스 역할을 한다. 배열은 데이터들이 0번칸부터 차례로 존재했기 때문에, 맨뒤 원소를 제외한 데이터의 추가/삭제를 하려면 인덱스 전체를 다시 싹 뜯어고쳐야하므로 O(n)의 시간이 소요됐다. 하지만 해시테이블은 key를 Hash Function에 넣어서 나온 해시를 메모리 주소로 하는 장소에 데이터를 보관하기 때문에, 주소의 중복만 일어나지 않는다면 O(1)의 시간복잡도를 가진다. 다시 말해, 같은 key값은 언제나 같은 해시를..
2020.05.22 -
[배열] string 거꾸로 출력하기
function reverse(str){ if (!str || str.length=0; i--) { go += str[i] } return go } reverse("Hi My Name Is John") const reverse2 = str => [...str].reverse().join("") reverse2("Even more concise")
2020.05.21 -
[Array - VanillaJS] 배열 만들어보기
class myArray { constructor() { this.length = 0; this.data = {}; } get(index) { return this.data[index] } push(item) { this.data[this.length] = item; this.length++; } pop() { const data = this.data[this.length-1]; delete this.data[this.length-1]; this.length--; return data; } delete(index) { const item = this.data[index]; this.shiftItems(index); } shiftItems(index) { for (let i=index; i
2020.05.21