Role of container in priority_queue of C++ STL.
Why vectors are used in container.
And what are advantages and disadvantages if I use deque instead of vector.
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 160 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | Dominater069 | 154 |
8 | awoo | 154 |
10 | luogu_official | 151 |
Role of container in priority_queue of C++ STL.
Why vectors are used in container.
And what are advantages and disadvantages if I use deque instead of vector.
Name |
---|
The design of
std::priority_queue
is such that you're allowed to specify which container you want to use to internally represent the priority queue. All it requires is that the container allows for random access, and has thefront
,push_back
andpop_back
functions. So bothstd::vector
andstd::deque
can be used as the underlying container.There's not really much of a difference apart from the usual difference between
std::vector
andstd::deque
. However, in practice,std::vector
tends to be faster.Reference implementations: https://judge.yosupo.jp/submission/56329 (Dijkstra with deque) and https://judge.yosupo.jp/submission/52076 (Dijkstra with vector).