Как я могу построить или вернуть основную деку из стека? - PullRequest
6 голосов
/ 13 июня 2010

Я хочу иметь возможность конвертировать std :: stack <> в std :: deque <>. Есть ли прямое преобразование?

Ответы [ 4 ]

17 голосов
/ 14 июня 2010

Можно получить доступ к нижележащему контейнеру без копирования данных, но это требует определенного количества зла.Контейнер представляет собой защищенный элемент, называемый c, который допускает такие махинации:

template <typename T>
class Shenanigans : private stack<T>
{
public:
    explicit Shenanigans(stack<T>& victim) : victim(victim)
    {
        swap(victim);
    }

    ~Shenanigans()
    {
        swap(victim);
    }

    using stack<T>::c;

private:
    stack<T>& victim;
};

int main()
{
    stack<int> s;
    s.push(42);

    {
        Shenanigans<int> sh(s);
        // The deque is accessible as sh.c, but the stack is temporarily empty.
        cout << "Size: " << s.size() << " Data: " << sh.c.front() << "\n";
    }

    // The stack is restored.
    cout << "Size: " << s.size() << " Data: " << s.top() << "\n";
}

Конечно, гораздо лучшим решением будет выбрать контейнер, который соответствует вашим потребностям.

6 голосов
/ 13 июня 2010

Вам нужно будет сделать это вручную:

while (!stk.empty())
{
    deq.push_back(stk.top());
    stk.pop();
}
3 голосов
/ 13 июня 2010

Вам нужно выложить все элементы из стека в другой контейнер.

Если вам нужно сделать это, возможно, std::stack - это неправильная структура данных для вашего варианта использования.

2 голосов
/ 13 июня 2010

Я думаю, что если вам это нужно, вам лучше использовать deque, а не стек.Невозможно получить доступ к базовому хранилищу, используемому адаптером стека, если вы об этом спрашиваете.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...