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++

[STL] set

2022. 1. 18. 20:07
728x90

Set์˜ ํŠน์ง•

- ์›์†Œ๊ฐ€ ์‚ฝ์ž…๋˜๋ฉด ์ž๋™์œผ๋กœ ์ •๋ ฌ

set<string>s; // ์˜ค๋ฆ„์ฐจ์ˆœ
set<string, greater<>>s; // ๋‚ด๋ฆผ์ฐจ์ˆœ

- ์ค‘๋ณต๊ฐ’์„ ํ—ˆ์šฉํ•˜์ง€ ์•Š๋Š”๋‹ค.

set์— ์›์†Œ๊ฐ€ ๋“ค์–ด๊ฐ€๋ฉด ๊ทธ ์›์†Œ์˜ ๊ฐ’์„ ํ‚ค(key)๋ผ๊ณ  ํ•˜๋ฉฐ

์ค‘๋ณต์›์†Œ๋ฅผ ํ—ˆ์šฉํ•˜์ง€ ์•Š๊ธฐ ๋•Œ๋ฌธ์— ๊ฐ ํ‚ค๋Š” ์ „๋ถ€ ๊ณ ์œ ํ•˜๋‹ค.

 

Set์„ ์‚ฌ์šฉํ•˜๊ธฐ ์ข‹์€ ๊ฒฝ์šฐ

1. ์‚ฝ์ž…๊ณผ ๋™์‹œ์— ์ •๋ ฌ์ด ํ•„์š”ํ•  ๋•Œ

2. ์ค‘๋ณต์„ ์ œ๊ฑฐํ•œ ์›์†Œ์˜ ์ง‘ํ•ฉ์ด ํ•„์š”ํ•  ๋•Œ

3. ์ƒˆ๋กœ ์‚ฝ์ž…ํ•˜๋ ค๋Š” ์›์†Œ๊ฐ€ ์ค‘๋ณต์ธ์ง€ ํ™•์ธํ•  ๋•Œ

set<string>s;
std::pair<set<string>::iterator,bool> ret;
ret = s.insert("a"); // s={a}
cout<< ret.second <<endl; // ์ถœ๋ ฅ 1
ret = s.insert("a"); // s={a}
cout<< ret.second <<endl; // ์ถœ๋ ฅ 0, a๊ฐ€ ์ด๋ฏธ ์žˆ์—ˆ์œผ๋ฏ€๋กœ

 

lower_bound(๊ฐ’), upper_bound(๊ฐ’), find(์›์†Œ), count(์›์†Œ)๋„ ํ™œ์šฉํ•  ์—ฌ์ง€๊ฐ€ ๋งŽ์„ ๊ฒƒ ๊ฐ™๋‹ค.

set์— ๋Œ€ํ•ด ์ž˜ ์ •๋ฆฌํ•ด์ฃผ์‹  ๋ธ”๋กœ๊ทธ : [C++, STL] ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ’€์ด๋ฅผ ์œ„ํ•œ ์…‹(set) - ์ฝ”๋“œ ๋‹ค์ด์–ด๋ฆฌ (tistory.com) 

 

 

728x90

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

[STL] deque  (0) 2022.01.18
[STL] ์šฐ์„ ์ˆœ์œ„ ํ priority_queue  (0) 2022.01.18
[STL] unique๋กœ vector์—์„œ ์ค‘๋ณต ์›์†Œ ์ œ๊ฑฐํ•˜๊ธฐ : ์„  sort ํ›„ unique!  (0) 2022.01.16
[STL] map์—์„œ Value๋ฅผ ๊ธฐ์ค€์œผ๋กœ ์ •๋ ฌํ•˜๊ณ  ์‹ถ์„ ๊ฒฝ์šฐ  (0) 2022.01.15
[STL] map  (0) 2022.01.15
    'C++/c++' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [STL] deque
    • [STL] ์šฐ์„ ์ˆœ์œ„ ํ priority_queue
    • [STL] unique๋กœ vector์—์„œ ์ค‘๋ณต ์›์†Œ ์ œ๊ฑฐํ•˜๊ธฐ : ์„  sort ํ›„ unique!
    • [STL] map์—์„œ Value๋ฅผ ๊ธฐ์ค€์œผ๋กœ ์ •๋ ฌํ•˜๊ณ  ์‹ถ์„ ๊ฒฝ์šฐ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

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