STL Container - Associate Container
Associate Container(์ฐ๊ด ์ปจํ ์ด๋)๋ ํค์ ๊ฐ์ฒ๋ผ ๊ด๋ จ์๋ ๋ฐ์ดํฐ๋ฅผ ํ๋์ ์์ผ๋ก ์ ์ฅํ๋ ์ปจํ ์ด๋์ด๋ค. ํค์ ๊ฐ์ ์ด์ฉํ์ฌ ์์๋ค์ ๋ํด ๋น ๋ฅธ ์ ๊ทผ์ด ๊ฐ๋ฅํ๋ค. ํ์ง๋ง ์ฝ์ ๋๋ ์์์ ์์น๋ฅผ ์ง์ ํ ์ ์๋ค.
๋ณดํต balanced binary search tree๋ hash table์ ์ด์ฉํ์ฌ ๊ตฌํํ๋ค.
set & multiset
์งํฉ(set)์ ์ ์ฅํ๋ ๋ฐ์ดํฐ ๊ทธ ์์ฒด๋ฅผ ํค๋ก ์ฌ์ฉํ๋ ๊ฐ์ฅ ๋จ์ํ ์ฐ๊ด ์ปจํ ์ด๋์ด๋ค. set์ ๋ฌ๋ฆฌ ์ค๋ฆ์ฐจ์์ผ๋ก ์ ๋ ฌ๋ ์์น์ ์์๋ฅผ ์ฝ์ ํ๋ฏ๋ก ๊ฒ์์๋๊ฐ ๋งค์ฐ ๋น ๋ฅด๋ค.
์งํฉ์์ ํค๋ ์ ์ผํด์ผํ๋ฏ๋ก, ํค์ ์ค๋ณต์ ํ์ฉํ์ง ์๋๋ค.
๋ฉํฐ์งํฉ(multiset)์ ํค์ ์ค๋ณต์ ํ์ฉํ๋ฉฐ, ๊ฐ์ ๊ฐ์ ์ฌ๋ฌ๋ฒ ์ ์ฅํ ์ ์๋ค.
๊ตฌ์กฐ
์์ฑ์
์์ฑ์ | ์ค๋ช |
set s | s๋ ๋น ์ปจํ ์ด๋ |
set s(pred) | s๋ ๋น ์ปจํ ์ด๋๋ก ์ ๋ ฌ ๊ธฐ์ค์ pred ์กฐ๊ฑด์๋ฅผ ์ฌ์ฉ |
set s(s2) | s๋ s2 ์ปจํ ์ด๋์ ๋ณต์ฌ๋ณธ์ด๋ค.(๋ณต์ฌ ์์ฑ์ ํธ์ถ) |
set s(b,e) | s๋ ๋ฐ๋ณต์ ๊ตฌ๊ฐ [b,e)๋ก ์ด๊ธฐํ๋ ์์๋ฅผ ๊ฐ๋๋ค. |
set s(b,e,pred) | s๋ ๋ฐ๋ณต์ ๊ตฌ๊ฐ [b,e)๋ก ์ด๊ธฐํ๋ ์์๋ฅผ ๊ฐ๋๋ค. ์ ๋ ฌ๊ธฐ์ค์ pred ์กฐ๊ฑด์๋ฅผ ์ด์ฉํ๋ค. |
๋ฉค๋ฒํจ์
ํจ์ | ์ค๋ช |
s.clear() | s์ ๋ชจ๋ ์์๋ฅผ ์ ๊ฑฐ |
n=s.count(k) | ์์ k์ ๊ฐ์๋ฅผ ๋ฐํํ๋ค. |
s.empty() | v๊ฐ ๋น์๋์ง ์กฐ์ฌ |
p=s.begin() | p๋ s์ ์ฒซ ์์๋ฅผ ๊ฐ๋ฆฌํจ๋ค. |
p=s.end() | p๋ s์ ๋์ ํ์ํ๋ ๋ฐ๋ณต์ |
pr=s.equeal_range(k) | pr๋ ์์ k์ ๋ฐ๋ณต์ ๊ตฌ๊ฐ์ธ pair ๊ฐ์ฒด |
q=s.erase(p) | p๊ฐ ๊ฐ๋ฆฌํค๋ ์์๋ฅผ ์ ๊ฑฐํ๋ค. q๋ ๋ค์ ์์๋ฅผ ๊ฐ๋ฆฌํจ๋ค. |
q=s.erase(b,e) | ๋ฐ๋ณต์ ๊ตฌ๊ฐ [b,e)์ ๋ชจ๋ ์์๋ฅผ ์ ๊ฑฐํ๋ค. q๋ ๋ค์ ์์๋ฅผ ๊ฐ๋ฆฌํจ๋ค. |
p=s.find(k) | p๋ k์์์ ์์น๋ฅผ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์์ด๋ค. |
pr=s.insert(k) | s ์ปจํ ์ด๋์ k๋ฅผ ์ฝ์ ํ๋ค. pr์ ์ฝ์ ํ ์์๋ฅผ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์์ ์ฑ๊ณต ์ฌ๋ถ์ bool์ธ pair ๊ฐ์ฒด์ด๋ค. |
q=s.insert(p,x) | p๊ฐ ๊ฐ๋ฆฌํค๋ ์์น์ k๊ฐ์ ์ฝ์ ํ๋ค. q๋ ์ฝ์ ํ ์์๋ฅผ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์๋ค. |
s.insert(b,e) | ๋ฐ๋ณต์ ๊ตฌ๊ฐ [b,e)์ ์์๋ฅผ ์ฝ์ ํ๋ค. |
pred = s.key_comp() | pred๋ s์ key ์ ๋ ฌ๊ธฐ์ค์ธ ์กฐ๊ฑด์์ด๋ค.(key_compare ํ์ ) |
pred = s.value_comp() | pred๋ s์ value ์ ๋ ฌ๊ธฐ์ค์ธ ์กฐ๊ฑด์์ด๋ค.(value_compare ํ์ ) |
p = s.lower_bound(k) | p๋ k์ ์์๊ตฌ๊ฐ์ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์์ด๋ค. |
p = s.upper_bound(k) | p๋ k์ ๋ ๊ตฌ๊ฐ์ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์์ด๋ค. |
x=s.max_size() | x๋ s๊ฐ ๋ด์ ์ ์๋ ์ต๋ ์์์ ๊ฐ์(๋ฉ๋ชจ๋ฆฌ์ ํฌ๊ธฐ) |
p=s.rbegin() | p๋ s์ ์ญ ์์ฐจ์ด์ ์ฒซ ์์๋ฅผ ๊ฐ๋ฆฌํค๋ ๋ฐ๋ณต์๋ค. |
p=s.rend() | p๋ s์ ์ญ ์์ฐจ์ด์ ๋์ ํ์ํ๋ ๋ฐ๋ณต์ |
s.size() | s์ ์์ ๊ฐฏ์ |
s.swap(s2) | s์ s2๋ฅผ swapํ๋ค. |
์ฐ๊ด ์ปจํ
์ด๋๋ ์ ๋ ฌ ๊ธฐ์ค์ด ์์ผ๋ฏ๋ก insert()
์ ์ํด ์ฝ์
๋ ์์๋ ์๋ ์ ๋ ฌ๋๋ค. set์์ ์์๋ฅผ key๋ผ ํ๋ฉฐ, ์ด ํค๋ฅผ ๋น๊ตํ์ฌ ๋ด๋ถ ์์๋ฅผ ์ ๋ ฌํ๋ค.
์์
set
multiset
map & multimap
map์ ํค์ ๊ฐ์ ์์ผ๋ก ๋ฐ์ดํฐ๋ฅผ ๊ด๋ฆฌํ๋ ์ปจํ ์ด๋์ด๋ค. ์งํฉ ์ปจํ ์ด๋์ ๋ง์ฐฌ๊ฐ์ง๋ก ์ ๋ ฌ๋ ์์น์ ์์๋ฅผ ์ฝ์ ํ๋ฏ๋ก ๊ฒ์ ์๋๊ฐ ๋งค์ฐ ๋น ๋ฅด๋ค.
map์์ ํค๋ ์ ์ผํด์ผํ๋ฏ๋ก, ํ๋์ ํค์ ํ๋์ ๊ฐ๋ง์ด ์ฐ๊ฒฐ๋ ์ ์๋ค. multimap์ ๊ฐ์ ์ค๋ณต์ ํ์ฉํ๋ฏ๋ก, ํ๋์ ํค์ ์ฌ๋ฌ ๊ฐ์ ๊ฐ๊ณผ ์ฐ๊ฒฐ๋ ์ ์๋ค.
๊ตฌ์กฐ
์์
map์ set๊ณผ ๊ฐ์ ์ธํฐํ์ด์ค ๋ฉค๋ฒ ํจ์๋ฅผ ์ ๊ณตํ๋ฉฐ, ํ ํ๋ฆฟ ํ์๊ณผ ๋ด์ฅ ๋ฉค๋ฒ ํ์๋ง์ด ์ฝ๊ฐ ์ฐจ์ด๋ฅผ ๋ณด์ธ๋ค.
map์
[]
์ฐ์ฐ์๋ฅผ ์ ๊ณตํ์ฌ key์ ํด๋นํ๋ ์์์ value์ ์ฝ๊ฒ ์ ๊ทผํ๊ฑฐ๋ ๋ณ๊ฒฝํ ์ ์๋ค.map
multimap
unordered associate container
์์๊ฐ ์ง์ ๋์ง ์์ ์ฐ๊ด ์ปจํ ์ด๋๋ ์์๊ฐ ์ง์ ๋ ๊ธฐ์กด ์ฐ๊ด ์ปจํ ์ด๋์ ๊ฐ์ ๋์์ ํ๋ค. ๊ธฐ์กด์ ์ฐ๊ด ์ปจํ ์ด๋๋ tree ๊ตฌ์กฐ๋ฅผ ๊ธฐ๋ฐ์ผ๋ก ๋์ํ์ง๋ง, ์ด ์ปจํ ์ด๋๋ hash table์ ๊ธฐ๋ฐ์ผ๋ก ๋์ํ๋ค.
๋ฐ๋ผ์, ์์์ ์ถ๊ฐ, ์ญ์ ์๋๊ฐ ๋นจ๋ผ์ก์ผ๋ฉฐ, ๋ค์ํ ๊ฒ์ ์๊ณ ๋ฆฌ์ฆ์ ์ฌ์ฉํ ์ ์๊ฒ ๋์๋ค. ์์๊ฐ ์ง์ ๋ ์ฐ๊ด ์ปจํ ์ด๋๋ ์๋ฐฉํฅ ๋ฐ๋ณต์๋ฅผ ์ง์ํ์ง๋ง, ์ด ์ปจํ ์ด๋๋ ์๋ฐํฅ ๋ฐ๋ณต์๋ง์ ์ง์ํ๋ค.
unordered_set
unordered_multiset
unordered_map
unordered_multimap
์ฐธ์กฐ
Last updated