С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/40: Рейтинг темы: голосов - 40, средняя оценка - 4.63
2 / 2 / 0
Регистрация: 08.12.2015
Сообщений: 210

Класс стека

25.03.2019, 09:57. Показов 7688. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, помогите, пожалуйста, решить данные задачи, используя класс для работы со стеком.

1. Дан стек заполненный случайным образом, из целых чисел. Удалить из него все отрицательные элементы, используя второй стек и одну переменную.
2. Дан стек, содержащий целые числа. Используя второй стек, записать в дно стека сумму всех элементов, при этом предыдущие элементы тоже добавить в данный стек (в том же порядке, если это возможно).
Python
1
2
3
4
5
6
7
8
9
10
11
12
class Stack:
  def __init__(self): 
    self.items = []
 
  def push(self, item): 
    self.items.append(item)
 
  def pop(self): 
    return self.items.pop() 
 
  def is_empty(self): 
    return (self.items == [])
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.03.2019, 09:57
Ответы с готовыми решениями:

Дан указатель Р1 на вершину непустого стека. Создать два новых стека, переместив в первый из них все элементы исходного стека с четными значениями, а
Помогите срочно составить задачу: Дан указатель Р1 на вершину непустого стека. Создать два новых стека, переместив в первый из них все...

Дан указатель Top1 на вершину непустого стека. Создать два новых стека, переместив в первый из них все элементы исходного стека с четными значениями,
Здравствуйте, Уважаемые пользователи!!! Помогите пожалуйста решить данную задачу : Дан указатель Top1 на вершину непустого стека....

Класс стека
Здравствуйте!помогите создать класс стека, чтобы входные данные были из списка....как я понимаю, это должно быть в конструкторе или нет? ...

3
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
26.03.2019, 17:08
Лучший ответ Сообщение было отмечено ruletik как решение

Решение

Сами задания находятся в строках:
1 Задание стр. 19-26
2 Задание стр. 42-47
Код в этих строках соответствует условиям заданий.

Все остальные строки, это вспомогательные для проверки, и потому не обязательные.
Поэтому все дополнительные средства, которые в них присутствуют (дополнительные переменные), не относятся к условию задачи.

Python
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
class Stack:
  def __init__(self): 
    self.items = []
 
  def push(self, item): 
    self.items.append(item)
 
  def pop(self): 
    return self.items.pop() 
 
  def is_empty(self): 
    return (self.items == [])
 
if __name__ == '__main__':
    L = list(map(int, input('Введите целые числа: ').split()))
    S = Stack()
    for i in L:          # Заполняем стек
        S.push(i)
    T = Stack()          # Начинаем выполнять задание 1
    x = 0
    while S.items:
        x = S.pop()
        if x >= 0:
            T.push(x)
    while T.items:
        S.push(T.pop())
 
    # Проверка содержимого стека S
    L =[]
    while S.items:
        L.append(S.pop())
    L.reverse()
    print(L)
 
    # Задание 2 (числа для стека берем из предыдущего примера
    #            те положительные , что остались в S после того,
    #            как убрали отрицательные)
 
    S2 = Stack()
    for i in L:          # Заполняем стек
        S2.push(i)
    T = Stack()          # Начинаем выполнять задание 2
    while S2.items:
        T.push(S2.pop())
    S2.push(sum(T.items))
    while T.items:
        S2.push(T.pop())
 
    # Проверка содержимого стека S2
    L =[]
    while S2.items:
        L.append(S2.pop())
    L.reverse()
    print(L)
Вывод:
Python
1
2
3
Введите целые числа: 1 -2 3 -4 5 -6 7
[1, 3, 5, 7]
[16, 1, 3, 5, 7]
1
2 / 2 / 0
Регистрация: 08.12.2015
Сообщений: 210
26.03.2019, 22:47  [ТС]
Viktorrus, спасибо большое!!! У меня частично самой не получалось
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
27.03.2019, 19:56
Лучший ответ Сообщение было отмечено ruletik как решение

Решение

Подумав значительно упростил код. Использовал атрибут items, что бы убрать не нужный список L.
Python
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
class Stack:
  def __init__(self): 
    self.items = []
 
  def push(self, item): 
    self.items.append(item)
 
  def pop(self): 
    return self.items.pop() 
 
  def is_empty(self): 
    return (self.items == [])
 
if __name__ == '__main__':
    S = Stack()
    S.items = list(map(int, input('Введите целые числа: ').split())) # Заполнение стека
    T = Stack()          # Начинаем выполнять задание 1
    x = 0
    while S.items:
        x = S.pop()
        if x >= 0:
            T.push(x)
    while T.items:
        S.push(T.pop())
 
    # Проверка содержимого стека S
    print(S.items)
 
    # Задание 2 (числа для стека берем из предыдущего примера
    #            те положительные, что остались в S после того,
    #            как убрали отрицательные)
 
    S2 = Stack()
    S2.items = S.items
    T = Stack()          # Начинаем выполнять задание 2
    while S2.items:
        T.push(S2.pop())
    S2.push(sum(T.items))
    while T.items:
        S2.push(T.pop())
 
    # Проверка содержимого стека S2
    print(S2.items)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.03.2019, 19:56
Помогаю со студенческими работами здесь

Класс стека
нужна помаш в написание одной программы(задачи) вот сама задача: Задание: Реализовать и протестировать контейнерный класс...

Реализовать класс стека
Нужно реализовать класс стека. Элементами стека должны быть объекты класса вагона. В классе вагона нужно отобразить тип вагона и его номер...

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

Класс итератор для стека
Доброго времени суток! Обращаюсь к вам за помощью. Хоть сама в тему эту не совсем влилась, прошу гляньте код. Ругается, но я...

Класс стека на связном списке
Попытался написать программу: /** \file CLStack.h \заголовочный файл статической библиотеки класс стека на связном списке */ ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru