std::stack<T,Container>::push
From cppreference.com
| void push( const value_type& value ); |
(1) | |
| void push( value_type&& value ); |
(2) | (C++11以降) |
指定された要素 value をスタックのトップにプッシュします。
1) 次に相当します: c.push_back(value)。
2) 次に相当します: c.push_back(std::move(value))。
目次 |
[編集] パラメータ
| value | - | 挿入する要素の値 |
[編集] 戻り値
(なし)
[編集] 計算量
Container::push_back と同等の計算量です。
[編集] 例
このプログラムは、 std::stack の使用が対応する括弧を処理する慣用的な方法である場合、 BrainHack DSL を実装します。
このコードを実行
#include <array> #include <cstdint> #include <iostream> #include <map> #include <stack> #include <stdexcept> #include <string_view> class BrainHackInterpreter { std::map<unsigned, unsigned> open_brackets, close_brackets; std::array<std::uint8_t, 32768> data_{0}; unsigned program_{0}; int pos_{0}; void collect_brackets(const std::string_view program) { std::stack<unsigned> brackets_stack; for (auto pos{0U}; pos != program.length(); ++pos) { if (const char c{program[pos]}; '[' == c) brackets_stack.push(pos); else if (']' == c) { if (brackets_stack.empty()) throw std::runtime_error("Brackets [] do not match!"); else { open_brackets[brackets_stack.top()] = pos; close_brackets[pos] = brackets_stack.top(); brackets_stack.pop(); } } } if (!brackets_stack.empty()) throw std::runtime_error("Brackets [] do not match!"); } void check_data_pos(int pos) { if (pos < 0 or static_cast<int>(data_.size()) <= pos) throw std::out_of_range{"Data pointer out of bound!"}; } public: BrainHackInterpreter(const std::string_view program) { for (collect_brackets(program); program_ < program.length(); ++program_) switch (program[program_]) { case '<': check_data_pos(--pos_); break; case '>': check_data_pos(++pos_); break; case '-': --data_[pos_]; break; case '+': ++data_[pos_]; break; case '.': std::cout << data_[pos_]; break; case ',': std::cin >> data_[pos_]; break; case '[': if (data_[pos_] == 0) program_ = open_brackets[program_]; break; case ']': if (data_[pos_] != 0) program_ = close_brackets[program_]; break; } } }; int main() { BrainHackInterpreter { "++++++++[>++>>++>++++>++++<<<<<-]>[<+++>>+++<-]>[<+" "+>>>+<<-]<[>+>+<<-]>>>--------.<<+++++++++.<<----.>" ">>>>.<<<------.>..++.<++.+.-.>.<.>----.<--.++.>>>+." }; std::cout << '\n'; }
出力
Hi, cppreference!
[編集] 関連項目
| (C++11) |
要素をトップにインプレースで構築する (公開メンバ関数) |
| トップ要素を削除する (public member function) |