Форум программистов, компьютерный форум CyberForum.ru

Можно ли считать односвязный список стеком? - C++

Восстановить пароль Регистрация
 
GMeloman
0 / 0 / 0
Регистрация: 10.06.2012
Сообщений: 10
25.06.2012, 11:25     Можно ли считать односвязный список стеком? #1
подскажите пожалуйста, можно ли считать односвязный список стеком?
если да подскажите код пожалуйста..
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
25.06.2012, 11:27     Можно ли считать односвязный список стеком? #2
GMeloman, LIFO - Last In First Out. У вас же FIFO - First In First Out.
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,693
25.06.2012, 11:28     Можно ли считать односвязный список стеком? #3
ну, в стеке элементы добавляются в начало, а тут добавляются в конец.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
25.06.2012, 11:30     Можно ли считать односвязный список стеком? #4
neske, Я бы не сказал, что это является обязательным условием.
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,693
25.06.2012, 11:32     Можно ли считать односвязный список стеком? #5
почему?
Catstail
Модератор
 Аватар для Catstail
21486 / 10239 / 1668
Регистрация: 12.02.2012
Сообщений: 17,120
25.06.2012, 11:32     Можно ли считать односвязный список стеком? #6
Список можно использовать как стек. Если элементы добавлять в начало списка. И брать из начала.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
25.06.2012, 11:40     Можно ли считать односвязный список стеком? #7
neske, Разве не стек?

C++
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
57
58
59
60
61
62
#include <iostream>
 
template<typename T>
struct Node
{
   Node(const T& val, Node* n = 0):
   value(val), next(n)
   {
   }
   T value;
   Node* next;
};
 
template<typename T>
class Stack
{
public:
   Stack():head(0), top_(head)
   {
   }
   void push(const T& value)
   {
      Node<T>* tmp = new Node<T>(value);
      if (!top_)
      {
         top_ = head = tmp;
      }
      else
      {
         tmp->next = top_;
         top_ = tmp;
      }
   }
   const T top() const
   {
      return top_->value;
   }
   bool empty() const { return !top_; }
   void pop()
   {
      Node<T>* tmp = top_;
      top_ = top_->next;
      delete tmp;
   }
private:
   Node<T>* head;
   Node<T>* top_;
};
 
int main()
{
   Stack<int> stck;
   stck.push(1);
   stck.push(2);
   stck.push(3);
   stck.push(4);
   while (!stck.empty())
   {
      std::cout << stck.top() << std::endl;
      stck.pop();
   }
}
http://liveworkspace.org/code/5490c5...1d97ca795a73ee

Добавлено через 2 минуты
Ну и реализация в том же gcc.

C++
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
      /**
       *  Returns a read/write reference to the data at the first
       *  element of the %stack.
       */
      reference
      top()
      {
    __glibcxx_requires_nonempty();
    return c.back();
      }
 
      /**
       *  Returns a read-only (constant) reference to the data at the first
       *  element of the %stack.
       */
      const_reference
      top() const
      {
    __glibcxx_requires_nonempty();
    return c.back();
      }
 
      /**
       *  @brief  Add data to the top of the %stack.
       *  @param  x  Data to be added.
       *
       *  This is a typical %stack operation.  The function creates an
       *  element at the top of the %stack and assigns the given data
       *  to it.  The time complexity of the operation depends on the
       *  underlying sequence.
       */
      void
      push(const value_type& __x)
      { c.push_back(__x); }
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,693
25.06.2012, 11:42     Можно ли считать односвязный список стеком? #8
стек конечно, добавление/удаление в начало 8) только я не понял, что ты этим сказать хотел, ведь я это и говорил
GMeloman
0 / 0 / 0
Регистрация: 10.06.2012
Сообщений: 10
25.06.2012, 11:44  [ТС]     Можно ли считать односвязный список стеком? #9
а не подскажете ещЁ програмку которая работает исключительно с C++ а то я не знаю как сделать в вижал студио ><
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
25.06.2012, 11:45     Можно ли считать односвязный список стеком? #10
neske, В конец добавление идет) в обоих случаях.
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,693
25.06.2012, 11:53     Можно ли считать односвязный список стеком? #11
добавление/удаление с одного конца - достаточное условие ?)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.06.2012, 11:55     Можно ли считать односвязный список стеком?
Еще ссылки по теме:

C++ Сформировать список из 10 книг, используя динамическую структуру данных односвязный список
C++ Работа со стеком, список

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
25.06.2012, 11:55     Можно ли считать односвязный список стеком? #12
neske, Да)
Yandex
Объявления
25.06.2012, 11:55     Можно ли считать односвязный список стеком?
Ответ Создать тему
Опции темы

Текущее время: 23:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru