250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ์ปดํฌ์ง€์…˜
  • ์œ„์ž„
  • MySQL
  • ใ…ฃใ„ท

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

Javascript/Javascript

[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์ž๋ฃŒ๊ตฌ์กฐ ํ,์Šคํƒ, ํŠธ๋ฆฌ ๊ตฌํ˜„

2022. 4. 25. 15:14
728x90

์ถœ์ฒ˜ : https://helloworldjavascript.net/pages/282-data-structures.html

 

ํ, ์Šคํƒ, ํŠธ๋ฆฌ | JavaScript๋กœ ๋งŒ๋‚˜๋Š” ์„ธ์ƒ

์ฒ˜์Œ ์‹œ์ž‘ํ•˜๋Š” ์‚ฌ๋žŒ๋“ค์„ ์œ„ํ•œ JavaScript ๊ต์žฌ

helloworldjavascript.net

ํ, ์Šคํƒ, ํŠธ๋ฆฌ

 

์–ด๋–ค ๋ฐ์ดํ„ฐ์˜ ๊ตฌ์ฒด์ ์ธ ๊ตฌํ˜„ ๋ฐฉ์‹์€ ์ƒ๋žตํ•œ ์ฑ„, ๋ฐ์ดํ„ฐ์˜ ์ถ”์ƒ์  ํ˜•ํƒœ์™€ ๊ทธ ๋ฐ์ดํ„ฐ๋ฅผ ๋‹ค๋ฃจ๋Š” ๋ฐฉ๋ฒ•๋งŒ์„ ์ •ํ•ด๋†“์€ ๊ฒƒ์„ ๊ฐ€์ง€๊ณ  ADT(Abstract Data Type) ํ˜น์€ ์ถ”์ƒ ์ž๋ฃŒํ˜•์ด๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์ด ์ฑ•ํ„ฐ์—์„œ๋Š” ๋„๋ฆฌ ์‚ฌ์šฉ๋˜๋Š” ADT์ธ ํ, ์Šคํƒ, ํŠธ๋ฆฌ์— ๋Œ€ํ•ด ๋ฐฐ์›๋‹ˆ๋‹ค.

ํ (Queue)

ํ(queue)๋Š” ๋‹ค์Œ๊ณผ ๊ฐ™์€ ์„ฑ์งˆ์„ ๊ฐ–๋Š” ์ž๋ฃŒํ˜•์ž…๋‹ˆ๋‹ค.

  • ๋ฐ์ดํ„ฐ๋ฅผ ์ง‘์–ด๋„ฃ์„ ์ˆ˜ ์žˆ๋Š” ์„ ํ˜•(linear) ์ž๋ฃŒํ˜•์ž…๋‹ˆ๋‹ค.
  • ๋จผ์ € ์ง‘์–ด๋„ฃ์€ ๋ฐ์ดํ„ฐ๊ฐ€ ๋จผ์ € ๋‚˜์˜ต๋‹ˆ๋‹ค. ์ด ํŠน์ง•์„ ์ค„์—ฌ์„œ FIFO(First In First Out)๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.
  • ๋ฐ์ดํ„ฐ๋ฅผ ์ง‘์–ด๋„ฃ๋Š” enqueue, ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”์ถœํ•˜๋Š” dequeue ๋“ฑ์˜ ์ž‘์—…์„ ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

JavaScript์—์„œ๋Š” ๋ฐฐ์—ด์„ ์ด์šฉํ•ด์„œ ๊ฐ„๋‹จํ•˜๊ฒŒ ํ๋ฅผ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

 
class Queue {
  constructor() {
    this._arr = [];
  }
  enqueue(item) {
    this._arr.push(item);
  }
  dequeue() {
    return this._arr.shift();
  }
}

const queue = new Queue();
queue.enqueue(1);
queue.enqueue(2);
queue.enqueue(3);
queue.dequeue(); // 1

ํ๋Š” ์ˆœ์„œ๋Œ€๋กœ ์ฒ˜๋ฆฌํ•ด์•ผ ํ•˜๋Š” ์ž‘์—…์„ ์ž„์‹œ๋กœ ์ €์žฅํ•ด๋‘๋Š” ๋ฒ„ํผ(buffer)๋กœ์„œ ๋งŽ์ด ์‚ฌ์šฉ๋ฉ๋‹ˆ๋‹ค.

์Šคํƒ (Stack)

์Šคํƒ(stack) ๋‹ค์Œ๊ณผ ๊ฐ™์€ ์„ฑ์งˆ์„ ๊ฐ–๋Š” ์ž๋ฃŒํ˜•์ž…๋‹ˆ๋‹ค.

  • ๋ฐ์ดํ„ฐ๋ฅผ ์ง‘์–ด๋„ฃ์„ ์ˆ˜ ์žˆ๋Š” ์„ ํ˜•(linear) ์ž๋ฃŒํ˜•์ž…๋‹ˆ๋‹ค.
  • ๋‚˜์ค‘์— ์ง‘์–ด๋„ฃ์€ ๋ฐ์ดํ„ฐ๊ฐ€ ๋จผ์ € ๋‚˜์˜ต๋‹ˆ๋‹ค. ์ด ํŠน์ง•์„ ์ค„์—ฌ์„œ LIFO(Last In First Out)๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.
  • ๋ฐ์ดํ„ฐ๋ฅผ ์ง‘์–ด๋„ฃ๋Š” push, ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”์ถœํ•˜๋Š” pop, ๋งจ ๋‚˜์ค‘์— ์ง‘์–ด๋„ฃ์€ ๋ฐ์ดํ„ฐ๋ฅผ ํ™•์ธํ•˜๋Š” peek ๋“ฑ์˜ ์ž‘์—…์„ ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

JavaScript์—์„œ๋Š” ๋ฐฐ์—ด์„ ์ด์šฉํ•ด์„œ ๊ฐ„๋‹จํ•˜๊ฒŒ ์Šคํƒ์„ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

 
class Stack {
  constructor() {
    this._arr = [];
  }
  push(item) {
    this._arr.push(item);
  }
  pop() {
    return this._arr.pop();
  }
  peek() {
    return this._arr[this._arr.length - 1];
  }
}

const stack = new Stack();
stack.push(1);
stack.push(2);
stack.push(3);
stack.pop(); // 3

์Šคํƒ์€ ์„œ๋กœ ๊ด€๊ณ„๊ฐ€ ์žˆ๋Š” ์—ฌ๋Ÿฌ ์ž‘์—…์„ ์—ฐ๋‹ฌ์•„ ์ˆ˜ํ–‰ํ•˜๋ฉด์„œ ์ด์ „์˜ ์ž‘์—… ๋‚ด์šฉ์„ ์ €์žฅํ•ด ๋‘˜ ํ•„์š”๊ฐ€ ์žˆ์„ ๋•Œ ๋„๋ฆฌ ์‚ฌ์šฉ๋ฉ๋‹ˆ๋‹ค.

ํŠธ๋ฆฌ (Tree)

ํŠธ๋ฆฌ(tree)๋Š” ์—ฌ๋Ÿฌ ๋ฐ์ดํ„ฐ๊ฐ€ ๊ณ„์ธต ๊ตฌ์กฐ ์•ˆ์—์„œ ์„œ๋กœ ์—ฐ๊ฒฐ๋œ ํ˜•ํƒœ๋ฅผ ๋‚˜ํƒ€๋‚ผ ๋•Œ ์‚ฌ์šฉ๋ฉ๋‹ˆ๋‹ค.

ํŠธ๋ฆฌ๋ฅผ ๋‹ค๋ฃฐ ๋•Œ ์‚ฌ์šฉ๋˜๋Š” ๋ช‡ ๊ฐ€์ง€ ์šฉ์–ด๋ฅผ ์‚ดํŽด๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค.

  • ๋…ธ๋“œ(node) - ํŠธ๋ฆฌ ์•ˆ์— ๋“ค์–ด์žˆ๋Š” ๊ฐ ํ•ญ๋ชฉ์„ ๋งํ•ฉ๋‹ˆ๋‹ค.
  • ์ž์‹ ๋…ธ๋“œ(child node) - ๋…ธ๋“œ๋Š” ์—ฌ๋Ÿฌ ์ž์‹ ๋…ธ๋“œ๋ฅผ ๊ฐ€์งˆ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
  • ๋ถ€๋ชจ ๋…ธ๋“œ(parent node) - ๋…ธ๋“œ A๊ฐ€ ๋…ธ๋“œ B๋ฅผ ์ž์‹์œผ๋กœ ๊ฐ–๊ณ  ์žˆ๋‹ค๋ฉด, ๋…ธ๋“œ A๋ฅผ ๋…ธ๋“œ B์˜ '๋ถ€๋ชจ ๋…ธ๋“œ'๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.
  • ๋ฟŒ๋ฆฌ ๋…ธ๋“œ(root node) - ํŠธ๋ฆฌ์˜ ๊ฐ€์žฅ ์ƒ์ธต๋ถ€์— ์žˆ๋Š” ๋…ธ๋“œ๋ฅผ ๋งํ•ฉ๋‹ˆ๋‹ค.
  • ์žŽ ๋…ธ๋“œ(leaf node) - ์ž์‹ ๋…ธ๋“œ๊ฐ€ ์—†๋Š” ๋…ธ๋“œ๋ฅผ ๋งํ•ฉ๋‹ˆ๋‹ค.
  • ์กฐ์ƒ ๋…ธ๋“œ(ancestor node) - ๋…ธ๋“œ A์˜ ์ž์‹์„ ๋”ฐ๋ผ ๋‚ด๋ ค๊ฐ”์„ ๋•Œ ๋…ธ๋“œ B์— ๋„๋‹ฌํ•  ์ˆ˜ ์žˆ๋‹ค๋ฉด, ๋…ธ๋“œ A๋ฅผ ๋…ธ๋“œ B์˜ ์กฐ์ƒ ๋…ธ๋“œ๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.
  • ์ž์† ๋…ธ๋“œ(descendant node) - ๋…ธ๋“œ A๊ฐ€ ๋…ธ๋“œ B์˜ ์กฐ์ƒ ๋…ธ๋“œ์ผ ๋•Œ, ๋…ธ๋“œ B๋ฅผ ๋…ธ๋“œ A์˜ ์ž์† ๋…ธ๋“œ๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.
  • ํ˜•์ œ ๋…ธ๋“œ(sibling node) - ๊ฐ™์€ ๋ถ€๋ชจ ๋…ธ๋“œ๋ฅผ ๊ฐ–๋Š” ๋‹ค๋ฅธ ๋…ธ๋“œ๋ฅผ ๋ณด๊ณ  ํ˜•์ œ ๋…ธ๋“œ๋ผ๊ณ  ๋ถ€๋ฆ…๋‹ˆ๋‹ค.

์•„๋ž˜๋Š” ์•„์ฃผ ๊ฐ„๋‹จํ•œ ํ˜•ํƒœ์˜ Node๋ฅผ ๊ตฌํ˜„ํ•œ ์˜ˆ์ž…๋‹ˆ๋‹ค.

 
class Node {
  constructor(content, children = []) {
    this.content = content;
    this.children = children;
  }
}

const tree = new Node('hello', [
  new Node('world'),
  new Node('and'),
  new Node('fun', [
    new Node('javascript!')
  ])
]);

function traverse(node) {
  console.log(node.content);
  for (let child of node.children) {
    traverse(child);
  }
}

traverse(tree);
// hello world and fun javascript!

ํŠธ๋ฆฌ๋Š” ๊ณ„์ธต ๊ตฌ์กฐ๋ฅผ ๋‚˜ํƒ€๋‚ด๊ธฐ ์œ„ํ•ด, ๋˜ํ•œ ๊ณ„์ธต ๊ตฌ์กฐ๋ฅผ ํ†ตํ•ด ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ํšจ์œจ์„ ๋†’์ด๊ณ ์ž ํ•  ๋•Œ ๋„๋ฆฌ ์‚ฌ์šฉ๋ฉ๋‹ˆ๋‹ค.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

728x90

'Javascript > Javascript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] for๋ฌธ๊ณผ foreach ์‹ค์ „ ์˜ˆ์ œ ๋น„๊ต  (0) 2022.04.30
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] Array.from( {length} ๊ตฌ๋ฌธ์—์„œ {length}์€ ์œ ์‚ฌ๋ฐฐ์—ด?  (0) 2022.04.27
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] web api ๋ถˆ๋Ÿฌ์˜ค๊ธฐ  (0) 2022.04.24
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ  (0) 2022.04.19
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] how to remove array element javascript  (0) 2022.04.17
    'Javascript/Javascript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] for๋ฌธ๊ณผ foreach ์‹ค์ „ ์˜ˆ์ œ ๋น„๊ต
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] Array.from( {length} ๊ตฌ๋ฌธ์—์„œ {length}์€ ์œ ์‚ฌ๋ฐฐ์—ด?
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] web api ๋ถˆ๋Ÿฌ์˜ค๊ธฐ
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ˆ๋ ˆ์ดํ„ฐ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”