22. Queue, Stack, Hashtable ์‚ฌ์šฉ

2022. 4. 7. 09:31ยท๐Ÿ’ป Programming Language/C#

Queue(ํ)

  • Queue : ์„ ์ž…์„ ์ถœ(first in first out(FIFO)) ํ˜•ํƒœ์˜ ์ž๋ฃŒ๊ตฌ์กฐ
    • Enqueue : ๋ฐ์ดํ„ฐ๋ฅผ ์ž…๋ ฅ
    • Dequque : ๋ฐ์ดํ„ฐ๋ฅผ ์ถœ๋ ฅ
using System.Collections;

namespace QueueEx
{   
    class Program
    {
        static void Main(string[] args)
        {
            Queue q = new Queue();

            q.Enqueue(1);
            q.Enqueue(100);
            q.Enqueue(200);
            q.Dequeue();
            q.Enqueue(22.5);
            int aa = (int)q.Dequeue(); 
            // objํƒ€์ž…์œผ๋กœ ๋ฐ˜ํ™˜๋˜๋ฏ€๋กœ casting ํ•„์š”.
            q.Enqueue("๊ฐ€๋‚˜๋‹ค");

            while(q.Count > 0)
            {
                Console.WriteLine(q.Dequeue());
            }
        }
    }
}
Output

200
22.5
๊ฐ€๋‚˜๋‹ค
  • object ํƒ€์ž…์œผ๋กœ ๋ฐ˜ํ™˜๋˜๋Š” ๊ฒฝ์šฐ์—๋Š” casting์ด ํ•„์š”ํ•˜๋‹ค.

Stack(์Šคํƒ)

  • ์Šคํƒ(Stack) : ํ›„์ž…์„ ์ถœ(LIFO)์˜ ์ž๋ฃŒ๊ตฌ์กฐ
              ๋‚˜์ค‘์— ๋“ค์–ด์˜จ ๋ฐ์ดํ„ฐ๊ฐ€ ๋จผ์ € ์ถœ๋ ฅ๋˜๋Š” ์ž๋ฃŒ๊ตฌ์กฐ
  • Push : ๋ฐ์ดํ„ฐ ์ž…๋ ฅ ๋ฉ”์†Œ๋“œ
  • Pop : ๋ฐ์ดํ„ฐ ์ถœ๋ ฅ ๋ฉ”์†Œ๋“œ
using System.Collections;

namespace StackEx
{
     class Program
    {
        static void Main(string[] args)
        {
            Stack stack = new Stack();
            stack.Push(100);
            stack.Push(11);
            stack.Pop();
            stack.Push(2.33);
            stack.Pop();
            stack.Push("๋ฌธ์ž์—ด");

            while(stack.Count > 0)
            {
                Console.WriteLine(stack.Pop());
            }
        }
    }
}
Output

๋ฌธ์ž์—ด
100

Hashtable(ํ•ด์‹œํ…Œ์ด๋ธ”)

  • Hashtable : ๋ฐ์ดํ„ฐ๋ฅผ ํ‚ค-๊ฐ’(key-value)์Œ์œผ๋กœ ๊ฐ€์ง€๋Š” ์ž๋ฃŒ๊ตฌ์กฐ

  • Key๋ฅผ ์ด์šฉํ•ด ๋ฐ์ดํ„ฐ์— ์ ‘๊ทผํ•˜๊ณ  value๋ฅผ ์–ป๋Š”๋‹ค.

  • Hashing ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์ด์šฉํ•œ ๋ฐ์ดํ„ฐ ๊ฒ€์ƒ‰์ด ์ด๋ฃจ์–ด์ง€๋Š” ๋ฐฉ์‹์˜ ์ž๋ฃŒ๊ตฌ์กฐ์ด๋‹ค.

    • ์ด๋กœ์ธํ•ด ๋ฐฐ์—ด๊ณผ ๊ฐ™์€ ์†๋„๋ฅผ ๋‚ด๋ฉฐ ํƒ์ƒ‰์— ์žˆ์–ด O(1) => ์ƒ์ˆ˜์‹œ๊ฐ„ ์˜ ์‹œ๊ฐ„๋ณต์žก๋„๋ฅผ ๊ฐ€์ง„๋‹ค.
      • ํ‚ค๋ฅผ ์ด์šฉํ•ด ํ•œ๋ฒˆ์— ๋ฐ์ดํ„ฐ๊ฐ€ ์ €์žฅ๋˜์–ด ์žˆ๋Š” ์ปฌ๋ ‰์…˜ ๋‚ด์˜ ์ฃผ์†Œ๋ฅผ ๊ณ„์‚ฐํ•ด๋‚ธ๋‹ค.
    using System.Collections;
    

namespace HashtableEx
{
class Program
{
static void Main(string[] args)
{
Hashtable ht = new Hashtable();
ht["Apple"] = "์‚ฌ๊ณผ";
ht["Banana"] = "๋ฐ”๋‚˜๋‚˜";
ht["Orange"] = "์˜ค๋ Œ์ง€";

        Console.WriteLine(ht["Apple"]);
        Console.WriteLine(ht["Banana"]);
        Console.WriteLine(ht["Orange"]);
    }
}

}

 ```java
Output

์‚ฌ๊ณผ
๋ฐ”๋‚˜๋‚˜
์˜ค๋ Œ์ง€

์ „์ฒด ์ฝ”๋“œ

 using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine("-----ํ-----");
        Queue q = new Queue();

        q.Enqueue(1);
        q.Enqueue(100);
        q.Enqueue(200);
        q.Dequeue();
        q.Enqueue(22.5);
        int aa = (int)q.Dequeue();
        // objํƒ€์ž…์œผ๋กœ ๋ฐ˜ํ™˜๋˜๋ฏ€๋กœ casting ํ•„์š”.
        q.Enqueue("๊ฐ€๋‚˜๋‹ค");

        while (q.Count > 0)
        {
            Console.WriteLine(q.Dequeue());
        }

        Console.WriteLine("\n-----์Šคํƒ-----");

        Stack stack = new Stack();
        stack.Push(100);
        stack.Push(11);
        stack.Pop();
        stack.Push(2.33);
        stack.Pop();
        stack.Push("๋ฌธ์ž์—ด");

        while (stack.Count > 0)
        {
            Console.WriteLine(stack.Pop());
        }

        Console.WriteLine("\n-----ํ•ด์‹œํ…Œ์ด๋ธ”-----");

        Hashtable ht = new Hashtable();
        ht["Apple"] = "์‚ฌ๊ณผ";
        ht["Banana"] = "๋ฐ”๋‚˜๋‚˜";
        ht["Orange"] = "์˜ค๋ Œ์ง€";

        Console.WriteLine(ht["Apple"]);
        Console.WriteLine(ht["Banana"]);
        Console.WriteLine(ht["Orange"]);
    }
}
Output 

-----ํ-----
200
22.5
๊ฐ€๋‚˜๋‹ค

-----์Šคํƒ-----
๋ฌธ์ž์—ด
100

-----ํ•ด์‹œํ…Œ์ด๋ธ”-----
์‚ฌ๊ณผ
๋ฐ”๋‚˜๋‚˜
์˜ค๋ Œ์ง€

'๐Ÿ’ป Programming Language > C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

24. yield ํ‚ค์›Œ๋“œ  (0) 2022.04.07
23. ์ปฌ๋ ‰์…˜ ์ดˆ๊ธฐํ™”, ์ธ๋ฑ์„œ  (0) 2022.04.07
21. ArrayList ์‚ฌ์šฉํ•˜๊ธฐ  (0) 2022.04.07
20. ์ถ”์ƒํด๋ž˜์Šค์—์„œ ์ž๋™ ํ”„๋กœํผํ‹ฐ ์‚ฌ์šฉ๋ฒ•  (0) 2022.04.07
19. ์ธํ„ฐํŽ˜์ด์Šค์—์„œ ์ž๋™ ํ”„๋กœํผํ‹ฐ ์‚ฌ์šฉ๋ฒ•  (0) 2022.04.07
'๐Ÿ’ป Programming Language/C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • 24. yield ํ‚ค์›Œ๋“œ
  • 23. ์ปฌ๋ ‰์…˜ ์ดˆ๊ธฐํ™”, ์ธ๋ฑ์„œ
  • 21. ArrayList ์‚ฌ์šฉํ•˜๊ธฐ
  • 20. ์ถ”์ƒํด๋ž˜์Šค์—์„œ ์ž๋™ ํ”„๋กœํผํ‹ฐ ์‚ฌ์šฉ๋ฒ•
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      Flutter
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      ๋ฐฑ์ค€
      DART
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      ์ž๋ฃŒ๊ตฌ์กฐ
      sort
      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      c#
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      JS
      ์“ฐ์…จ์ž–์•„
      DP
      ์Šคํ„ฐ๋””
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      Algorithm
      JavaScript
      ํŒŒ์ด์ฌ
      ์นด์นด์˜ค
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      ์ฝ”๋“œํŠธ๋ฆฌ
      programmers
      BAEKJOON
      ๊ตฌํ˜„
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      ์ด์ง„ํƒ์ƒ‰
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      ์‚ผ์„ฑsw์—ญํ…Œ
      BFS
      Java
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    22. Queue, Stack, Hashtable ์‚ฌ์šฉ
    ์ƒ๋‹จ์œผ๋กœ

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

    ๋‹จ์ถ•ํ‚ค

    ๋‚ด ๋ธ”๋กœ๊ทธ

    ๋‚ด ๋ธ”๋กœ๊ทธ - ๊ด€๋ฆฌ์ž ํ™ˆ ์ „ํ™˜
    Q
    Q
    ์ƒˆ ๊ธ€ ์“ฐ๊ธฐ
    W
    W

    ๋ธ”๋กœ๊ทธ ๊ฒŒ์‹œ๊ธ€

    ๊ธ€ ์ˆ˜์ • (๊ถŒํ•œ ์žˆ๋Š” ๊ฒฝ์šฐ)
    E
    E
    ๋Œ“๊ธ€ ์˜์—ญ์œผ๋กœ ์ด๋™
    C
    C

    ๋ชจ๋“  ์˜์—ญ

    ์ด ํŽ˜์ด์ง€์˜ URL ๋ณต์‚ฌ
    S
    S
    ๋งจ ์œ„๋กœ ์ด๋™
    T
    T
    ํ‹ฐ์Šคํ† ๋ฆฌ ํ™ˆ ์ด๋™
    H
    H
    ๋‹จ์ถ•ํ‚ค ์•ˆ๋‚ด
    Shift + /
    โ‡ง + /

    * ๋‹จ์ถ•ํ‚ค๋Š” ํ•œ๊ธ€/์˜๋ฌธ ๋Œ€์†Œ๋ฌธ์ž๋กœ ์ด์šฉ ๊ฐ€๋Šฅํ•˜๋ฉฐ, ํ‹ฐ์Šคํ† ๋ฆฌ ๊ธฐ๋ณธ ๋„๋ฉ”์ธ์—์„œ๋งŒ ๋™์ž‘ํ•ฉ๋‹ˆ๋‹ค.