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๐Ÿ“’

C#/์ด๊ฒƒ์ด C#์ด๋‹ค

53. ์ปฌ๋ ‰์…˜(ArrayList, Queue, Stack, Hashtable)

2022. 2. 25. 13:46
728x90

์ปฌ๋ ‰์…˜์ด๋ž€ ๊ฐ™์€ ์„ฑ๊ฒฉ์„ ๋ˆ ๋ฐ์ดํ„ฐ์˜ ๋ชจ์Œ์„ ๋‹ด๋Š” ์ž๋ฃŒ๊ตฌ์กฐ๋ฅผ ๋งํ•œ๋‹ค. 


public abstrack class Array : ICloneable, IList, ICollection, IEnumerable


- ArrayList

๊ฐ€์žฅ ๋ฐฐ์—ด๊ณผ ๋‹ฎ์€ ์ปฌ๋ ‰์…˜์ด๋‹ค. 

์ปฌ๋ ‰์…˜์˜ ์š”์†Œ์— ์ ‘๊ทผํ•  ๋•Œ๋Š” [ ] ์—ฐ์‚ฐ์ž๋ฅผ ์ด์šฉํ•˜๊ณ , ํŠน์ • ์œ„์น˜์— ์žˆ๋Š” ์š”์†Œ์— ๋ฐ์ดํ„ฐ๋ฅผ ์ž„์˜๋กœ ํ• ๋‹นํ•  ์ˆ˜ ์žˆ๋‹ค.

ํ•œํŽธ, ๋ฐฐ์—ด๊ณผ๋Š” ๋‹ฌ๋ฆฌ ์ปฌ๋ ‰์…˜์„ ์ƒ์„ฑํ•  ๋•Œ ์šฉ๋Ÿ‰์„ ๋ฏธ๋ฆฌ ์ง€์ •ํ•  ํ•„์š” ์—†์ด ํ•„์š”์— ๋”ฐ๋ผ ์ž๋™์œผ๋กœ ๊ทธ ์šฉ๋Ÿ‰์ด ๋Š˜์–ด๋‚˜๊ฑฐ๋‚˜ ์ค„์–ด๋“ ๋‹ค.

ArrayList์—์„œ ๊ฐ€์žฅ ์ค‘์š”ํ•œ ๋ฉ”์†Œ๋“œ๋Š” Add(), RemoveAt(), Insert() ์ด๋ ‡๊ฒŒ ์„ธ ๊ฐœ์ด๋‹ค.

Add() : ์ปฌ๋ ‰์…˜์˜ ๊ฐ€์žฅ ๋งˆ์ง€๋ง‰์— ์žˆ๋Š” ์š”์†Œ ๋’ค์— ์ƒˆ ์š”์†Œ๋ฅผ ์ถ”๊ฐ€

RemoveAt() : ํŠน์ • ์ธ๋ฑ์Šค์— ์žˆ๋Š” ์š”์†Œ๋ฅผ ์ œ๊ฑฐ

Insert() : ์›ํ•˜๋Š” ์œ„์น˜์— ์ƒˆ ์š”์†Œ๋ฅผ ์‚ฝ์ž…

 

<์˜ˆ์ œ>

using System;
using System.Collections;

namespace MoreOnArray
{
    class MainApp
    {
        static void Main(string[] args)
        {
            ArrayList list = new ArrayList();
            for (int i = 10; i < 60; i+=10)
                list.Add(i);

            foreach (var obj in list)
                Console.Write($"{obj} "); //10 20 30 40 50
            Console.WriteLine();

            list.RemoveAt(2);
            foreach (var obj in list)
                Console.Write($"{obj} "); //10 20 40 50
            Console.WriteLine();

            list.Insert(2,"๋ฐ”๋ณด");
            foreach (var obj in list)
                Console.Write($"{obj} "); //10 20 ๋ฐ”๋ณด 40 50
            Console.WriteLine();

            list.Add("abc");
            list.Add("def");
            foreach (var obj in list)
                Console.Write($"{obj} "); //10 20 ๋ฐ”๋ณด 40 50 abc def
            Console.WriteLine();
        }
    }
}

ArrayList๊ฐ€ ๋‹ค์–‘ํ•œ ํ˜•์‹์˜ ๊ฐ์ฒด๋ฅผ ๋‹ด์„ ์ˆ˜ ์žˆ๋Š” ์ด์œ ๋Š” ๋‹ค์Œ์˜ Add.Inset() ๋ฉ”์†Œ๋“œ ์„ ์–ธ์„ ๋ณด๋ฉด ์•Œ ์ˆ˜ ์žˆ๋‹ค.

public virtual int Add(Object value)

public virtual void Inset(int index, Object value)

 

object ํ˜•์‹์˜ ๋งค๊ฐœ๋ณ€์ˆ˜๋ฅผ ๋ฐ›๊ณ  ์žˆ๋‹ค.

๋ชจ๋“  ํ˜•์‹์€ object๋ฅผ ์ƒ์†ํ•˜๋ฏ€๋กœ object ํ˜•์‹์œผ๋กœ ๊ฐ„์ค„๋  ์ˆ˜ ์žˆ๋‹ค.

Add() ๋ฉ”์†Œ๋“œ์— int ํ˜•์‹์˜ ๋ฐ์ดํ„ฐ๋ฅผ ๋„ฃ๋”๋ผ๋„ ์ •์ˆ˜ ํ˜•์‹ ๊ทธ๋Œ€๋กœ ์ž…๋ ฅ๋˜๋Š” ๊ฒƒ์ด ์•„๋‹ˆ๋ผ object ํ˜•์‹์œผ๋กœ ๋ฐ•์‹ฑ๋˜์–ด ์ž…๋ ฅ๋˜๋Š” ๊ฒƒ์ด๋‹ค.

๋ฐ˜๋Œ€๋กœ ArrayList์˜ ์š”์†Œ์— ์ ‘๊ทผํ•ด์„œ ์‚ฌ์šฉํ•  ๋•Œ๋Š” ์›๋ž˜์˜ ๋ฐ์ดํ„ฐ ํ˜•์‹์œผ๋กœ ์–ธ๋ฐ•์‹ฑ์ด ์ด๋ฃจ์–ด์ง„๋‹ค.

๋ฐ•์‹ฑ๊ณผ ์–ธ๋ฐ•์‹ฑ์€ ์ž‘์ง€ ์•Š์€ ์˜ค๋ฒ„ํ—ค๋“œ๋ฅผ ์š”๊ตฌํ•˜๋Š” ์ž‘์—…์ด๋‹ค.

ArrayList๊ฐ€ ๋‹ค๋ฃจ๋Š” ๋ฐ์ดํ„ฐ๊ฐ€ ๋งŽ์œผ๋ฉด ๋งŽ์•„์งˆ์ˆ˜๋ก ์„ฑ๋Šฅ ์ €ํ•˜๋Š” ๋”์šฑ ๋Š˜์–ด๋‚œ๋‹ค.

์ด๊ฒƒ์€ ArrayList๋งŒ์˜ ๋ฌธ์ œ๊ฐ€ ์•„๋‹ˆ๋ผ Stack, Queue, Hashtable ๋“ฑ์˜ ์ปฌ๋ ‰์…˜๋„ ๊ฐ€์ง€๊ณ  ์žˆ๋‹ค.

์ผ๋ฐ˜ํ™” ์ปฌ๋ ‰์…˜์„ ์“ฐ๋ฉด ๋ฌธ์ œ๊ฐ€ ํ•ด์†Œ๋œ๋‹ค. 

 

- Queue

๋ฐ์ดํ„ฐ๋‚˜ ์ž‘์—…์„ ์ฐจ๋ก€๋Œ€๋กœ ์ž…๋ ฅํ•ด๋’€๋‹ค๊ฐ€ ์ž…๋ ฅ๋œ ์ˆœ์„œ๋Œ€๋กœ ํ•˜๋‚˜์”ฉ ๊บผ๋‚ด ์ฒ˜๋ฆฌํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋œ๋‹ค.

์ž…๋ ฅ์€ ์˜ค์ง ๋’ค์—์„œ, ์ถœ๋ ฅ์€ ์•ž์—์„œ๋งŒ ์ด๋ฃจ์–ด์ง„๋‹ค.

Queue๋Š” ์—„์ฒญ๋‚˜๊ฒŒ ๋‹ค์–‘ํ•œ ๋ถ„์•ผ์— ์‚ฌ์šฉ๋˜๊ณ  ์žˆ๋‹ค.

OS์—์„œ CPU๊ฐ€ ์ฒ˜๋ฆฌํ•ด์•ผ ํ•  ์ž‘์—…์„ ์ •๋ฆฌํ•  ๋•Œ, ํ”„๋ฆฐํ„ฐ๊ฐ€ ์—ฌ๋Ÿฌ ๋ฌธ์„œ๋ฅผ ์ถœ๋ ฅํ•  ๋•Œ, ์ธํ„ฐ๋„ท ๋™์˜์ƒ ์ŠคํŠธ๋ฆฌ๋ฐ ์„œ๋น„์Šค์—์„œ ์ฝ˜ํ…์ธ ๋ฅผ ๋ฒ„ํผ๋งํ•  ๋•Œ ๋“ฑ...

์ž…๋ ฅ : Enqueue()

์ถœ๋ ฅ : Dequeue()

<์˜ˆ์ œ>

using System;
using System.Collections;

namespace Collections
{
    class MainApp
    {
        static void Main(string[] args)
        {
            Queue que = new Queue();
            que.Enqueue(1);
            que.Enqueue(2);
            que.Enqueue(3);
            que.Enqueue(4);
            que.Enqueue(5);
            que.Enqueue(6);
            que.Enqueue(7);
            que.Enqueue(8);
            que.Enqueue(9);
            que.Enqueue(10);

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

<์ถœ๋ ฅ>

1
2
3
4
5
6
7
8
9
10

- Stack

์˜ˆ์ œ

using System;
using System.Collections;

namespace Collections
{
    class MainApp
    {
        static void Main(string[] args)
        {
            Stack que = new Stack();
            que.Push(1);
            que.Push(2);
            que.Push(3);
            que.Push(4);
            que.Push(5);
            que.Push(6);
            que.Push(7);
            que.Push(8);
            que.Push(9);
            que.Push(10);

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

์ถœ๋ ฅ

10
9
8
7
6
5
4
3
2
1

- Hashtable

์‚ฌ์ „ book์„ ํ‚ค๋กœ, ์ฑ…์„ ๊ฐ’์œผ๋กœ ์ž…๋ ฅํ•˜๋Š” ์‹

ํƒ์ƒ‰ ์†๋„๊ฐ€ ๋น ๋ฅด๊ณ  ์‚ฌ์šฉํ•˜๊ธฐ๋„ ํŽธํ•จ!

using System;
using System.Collections;

namespace Collections
{
    class MainApp
    {
        static void Main(string[] args)
        {
            Hashtable ht = new Hashtable();
            ht["book"] = "์ฑ…";
            ht["Worker"] = "์š”๋ฆฌ์‚ฌ";
            ht["tweet"] = "๋จธ์Šคํฌ์˜๋„์ง€";


            Console.WriteLine(ht["book"]); //์ฑ…
            Console.WriteLine(ht["Worker"]); //์š”๋ฆฌ์‚ฌ
            Console.WriteLine(ht["tweet"]); //๋จธ์Šคํฌ์˜๋„์ง€
        }
    }
}

๋ฐฐ์—ด๊ณผ ๋‹ค๋ฅธ ์ ์€ ๋ฐฐ์—ด์ด ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ•  ์š”์†Œ์˜ ์œ„์น˜๋กœ ์ธ๋ฑ์Šค๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๋ฐ˜๋ฉด์—,

Hashtable ์ปฌ๋ ‰์…˜์€ ํ‚ค ๋ฐ์ดํ„ฐ๋ฅผ ๊ทธ๋Œ€๋กœ ์‚ฌ์šฉํ•œ๋‹ค๋Š” ๊ฒƒ์ด๋‹ค.

 

์•ž์˜ ์˜ˆ์ œ์—์„œ๋Š” ๋ฌธ์ž์—ด์„ ์‚ฌ์šฉํ–ˆ์ง€๋งŒ ์–ด๋–ค ํ˜•์‹์ด๋“  ํ‚ค๋กœ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

int๋„ float ํ˜•์‹๋„ ํด๋ž˜์Šค๋„!

 

Hashtable์€ ๋ฐฐ์—ด์—์„œ ์ธ๋ฑ์Šค๋ฅผ ์ด์šฉํ•ด์„œ ๋ฐฐ์—ด ์š”์†Œ์— ์ ‘๊ทผํ•˜๋Š” ๊ฒƒ์— ์ค€ํ•˜๋Š” ํƒ์ƒ‰ ์†๋„๋ฅผ ์ž๋ž‘ํ•œ๋‹ค.

(ํƒ์ƒ‰ ์†๋„๊ฐ€ ๊ฑฐ์˜ ์†Œ์š”๋˜์ง€ ์•Š๋Š”๋‹ค.)

 

ArrayLlist์—์„œ ์›ํ•˜๋Š” ๋ฐ์ดํ„ฐ๋ฅผ ์ฐพ์œผ๋ ค๋ฉด ์ปฌ๋ ‰์…˜์„ ์ •๋ ฌํ•ด ์ด์ง„ ํƒ์ƒ‰์„ ์ˆ˜ํ–‰ํ•˜๊ฑฐ๋‚˜ ์ˆœ์ฐจ์ ์œผ๋กœ ๋ฆฌ์ŠคํŠธ๋ฅผ ํƒ์ƒ‰ํ•ด๋‚˜๊ฐ€์ง€๋งŒ, Hashtable์€ ํ‚ค๋ฅผ ์ด์šฉํ•ด์„œ ๋‹จ๋ฒˆ์— ๋ฐ์ดํ„ฐ๊ฐ€ ์ €์žฅ๋œ ์ปฌ๋ ‰์…˜ ๋‚ด์˜ ์ฃผ์†Œ๋ฅผ ๊ณ„์‚ฐํ•ด๋‚ธ๋‹ค.

์ด ์ž‘์—…์„ ํ•ด์‹ฑ์ด๋ผ๊ณ  ํ•˜๋Š”๋ฐ Hashtable์˜ ์ด๋ฆ„์€ ์ด ์•Œ๊ณ ๋ฆฌ์ฆ˜์—์„œ ์œ ๋ž˜ํ•œ ๊ฒƒ์ด๋‹ค.

 

<์ปฌ๋ ‰์…˜์„ ์ดˆ๊ธฐํ™”ํ•˜๋Š” ๋ฐฉ๋ฒ•>

ArrayList, Queue, Stack์€ ๋ฐฐ์—ด์˜ ๋„์›€์„ ๋ฐ›์•„ ๊ฐ„๋‹จํ•˜๊ฒŒ ์ดˆ๊ธฐํ™”๋ฅผ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์žˆ๋‹ค.

 

์ปฌ๋ ‰์…˜์˜ ์ƒ์„ฑ์ž๋ฅผ ํ˜ธ์ถœํ•  ๋•Œ ๋ฐฐ์—ด ๊ฐ์ฒด๋ฅผ ๋งค๊ฐœ๋ณ€์ˆ˜๋กœ ๋„˜๊ธฐ๋ฉด

์ปฌ๋ ‰์…˜ ๊ฐ์ฒด๋Š” ํ•ด๋‹น ๋ฐฐ์—ด์„ ๋ฐ”ํƒ•์œผ๋กœ ๋‚ด๋ถ€ ๋ฐ์ดํ„ฐ๋ฅผ ์ฑ„์šด๋‹ค.

๋‹ค์Œ์€ ์ปฌ๋ ‰์…˜์˜ ์ดˆ๊ธฐํ™”๋ฅผ ์ˆ˜ํ–‰ํ•˜๋Š” ์˜ˆ์ œ ์ฝ”๋“œ์ด๋‹ค.

 

<์˜ˆ์ œ>

using System;
using System.Collections;

namespace Collections
{
    class MainApp
    {
        static void Main(string[] args)
        {
            int[] arr = new int[] { 1, 2, 3, 4 };
            ArrayList list = new ArrayList(arr);
            Stack stack = new Stack(arr);
            Queue queue = new Queue(arr);

            ArrayList list2 = new ArrayList() { 1, 2, 3, 4 };

            foreach(var a in list)
            {
                Console.WriteLine($"{a} ");
            }
            Console.WriteLine();

            foreach (var a in stack)
            {
                Console.WriteLine($"{a} ");
            }
            Console.WriteLine();

            foreach (var a in queue)
            {
                Console.WriteLine($"{a} ");
            }
            Console.WriteLine();

            foreach (var a in list2)
            {
                Console.WriteLine($"{a} ");
            }
            Console.WriteLine();
        }
    }
}

<์ถœ๋ ฅ>

1
2
3
4

4
3
2
1

1
2
3
4

1
2
3
4

Hashtable์„ ์ดˆ๊ธฐํ™”ํ•  ๋•Œ๋Š” ๋”•์…”๋„ˆ๋ฆฌ ์ดˆ๊ธฐ์ž๋ฅผ ์ด์šฉํ•œ๋‹ค.

            Hashtable ht = new Hashtable()
            {
                ["ํ•˜๋‚˜"] = 1,
                ["๋‘˜"] = 2,
                ["์…‹"] = 3
            };

์•„๋ž˜์™€ ๊ฐ™์ด Hashtable์„ ์ดˆ๊ธฐํ™”ํ•  ๋•Œ๋„ ์ปฌ๋ ‰์…˜ ์ดˆ๊ธฐ์ž๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.
            Hashtable ht2 = new Hashtable()
            {
                { "ํ•˜๋‚˜",1},
                {"๋‘˜",2 },
                {"์…‹",3}
            };

728x90

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

55. foreach๊ฐ€ ๊ฐ€๋Šฅํ•œ ๊ฐ์ฒด ๋งŒ๋“ค๊ธฐ  (0) 2022.02.27
54. ์ธ๋ฑ์„œ  (0) 2022.02.25
52. ๊ฐ€๋ณ€๋ฐฐ์—ด  (0) 2022.02.25
51. ๋‹ค์ฐจ์›๋ฐฐ์—ด  (0) 2022.02.25
50. 2์ฐจ์› ๋ฐฐ์—ด  (0) 2022.02.24
    'C#/์ด๊ฒƒ์ด C#์ด๋‹ค' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • 55. foreach๊ฐ€ ๊ฐ€๋Šฅํ•œ ๊ฐ์ฒด ๋งŒ๋“ค๊ธฐ
    • 54. ์ธ๋ฑ์„œ
    • 52. ๊ฐ€๋ณ€๋ฐฐ์—ด
    • 51. ๋‹ค์ฐจ์›๋ฐฐ์—ด
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

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