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