티스토리 뷰
deque : double ended queue
멤버 | 원형 | 설명 |
---|---|---|
at | reference at( size_type _Pos ); const_reference at( size_type _Pos ) const; | 특정 위치의 원소의 참조를 반환 |
back | reference back( ); const_reference back( ) const; | 마지막 원소의 참조를 반환 |
begin | const_iterator begin() const; iterator begin(); | 첫 번째 원소의 랜던 접근 반복자를 반환 |
clear | void clear(); | 모든 원소를 삭제 |
empty | bool empty() const; | 아무것도 없으면 true 반환 |
end | iterator end( ); const_iterator end( ) const; | 마지막 원소 다음의(미 사용 영역) 반복자를 반환 |
front | reference front( ); const_reference front( ) const; | 첫 번째 원소의 참조를 반환 |
pop_back | void pop_back(); | 마지막 원소를 삭제 |
pop_front | void pop_front( ); | 첫 번째 원소를 삭제 |
push_back | void push_back( const Type& _Val ); | 마지막에 원소를 추가 |
push_front | void push_front( const Type& _Val ); | 제일 앞에 원소 추가 |
rbegin | reverse_iterator rbegin( ); const_reverse_iterator rbegin( ) const; | 역방향으로 첫 번째 원소의 반복자를 반환 |
rend | const_reverse_iterator rend( ) const; reverse_iterator rend( ); | 역방향으로 마지막 원소 다음의 반복자를 반환 |
size | size_type size() const; | 원소의 개수를 반환 |
(출처 : http://www.hanbit.co.kr/network/category/category_view.html?cms_code=CMS3942847236)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | #include <deque> #include <iostream> #include <string> using namespace std; int main() { int n; cin >> n; deque<int> d; while (n--) { string cmd; cin >> cmd; if (cmd == "push_front") { int num; cin >> num; d.push_front(num); } else if (cmd == "push_back") { int num; cin >> num; d.push_back(num); } else if (cmd == "pop_front") { if (d.empty()) { cout << -1 << '\n'; } else { cout << d.front() << '\n'; d.pop_front(); } } else if (cmd == "pop_back") { if (d.empty()) { cout << -1 << '\n'; } else { cout << d.back() << '\n'; d.pop_back(); } } else if (cmd == "size") { cout << d.size() << '\n'; } else if (cmd == "empty") { cout << d.empty() << '\n'; } else if (cmd == "front") { if (d.empty()) { cout << -1 << '\n'; } else { cout << d.front() << '\n'; } } else if (cmd == "back") { if (d.empty()) { cout << -1 << '\n'; } else { cout << d.back() << '\n'; } } } return 0; } | cs |
'알고리즘 > 자료구조' 카테고리의 다른 글
BOJ)10820 문자열 분석 (0) | 2017.06.20 |
---|---|
BOJ)1158 조세퍼스 문제 (0) | 2017.06.20 |
BOJ)1406 에디터 (0) | 2017.06.19 |
BOJ)10799 쇠막대기 (0) | 2017.06.19 |
BOJ)9012 괄호 (0) | 2017.06.19 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- DP
- WPF
- 객체
- CollectionView
- UIView Animation
- XAML
- BOJ
- Add TapGesture
- Cell Animation
- listview
- MVVM
- 백준
- dfs
- Custom Cell
- FEED
- BFS
- C++
- command
- 문자열
- 그래프
- 타일링
- 백준온라인
- 스택
- CustomCollectionViewCell
- 데이터 바인딩
- 코딩야학
- 생활코딩
- Fakebook
- Grid
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함