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

Очередь с защитой от ошибок

27.08.2022, 13:38. Показов 1109. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
ЗАДАЧА
Очередь с защитой от ошибок
Реализуйте структуру данных "очередь". Напишите программу, содержащую описание очереди и моделирующую работу очереди, реализовав все указанные здесь методы. Программа считывает последовательность команд и в зависимости от команды выполняет ту или иную операцию. После выполнения каждой команды программа должна вывести одну строчку. Возможные команды для программы:
push n — добавить в очередь число n (значение n задаётся после команды). Программа должна вывести ok;
pop — удалить из очереди первый элемент. Программа должна вывести его значение;
front — программа должна вывести значение первого элемента, не удаляя его из очереди;
size — программа должна вывести количество элементов в очереди;
clear — программа должна очистить очередь и вывести ok;
exit — программа должна вывести bye и завершить работу.
Перед исполнением операций front и pop программа должна проверять, содержится ли в очереди хотя бы один элемент. Если во входных данных встречается операция front или pop и при этом очередь пуста, то программа должна вместо числового значения вывести строку error.

Входные данные
Вводятся команды управления очередью, по одной команде в строке. Среди них обязательно присутствует команда exit.
Выходные данные
Требуется вывести протокол работы очереди, по одному сообщению в строке.
Мой код
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
g = []
logge = []
def log(msg):
    logge.append(msg)
while True:
    cm = input().split(' ')
    if (cm[0] == "push"):
        g.append(cm[1])
        log("ok")
    elif (cm[0] == "pop"):
        if(len(g) == 0): log("error")
        else:
            log(g[0])
            g.pop(g[0])
    elif (cm[0] == "front"):
        if(len(g) == 0): log("error")
        else: 
            log(g[0])
    elif (cm[0] == "size"): log(len(g))
    elif (cm[0] == "clear"):
        g.clear()
        log("ok")
    elif (cm[0] == "exit"):
        log("bye")
        break
for i in logge: print(i)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.08.2022, 13:38
Ответы с готовыми решениями:

Очередь с защитой от ошибок.Линейные структуры данных. Python
Очередь с защитой от ошибок Реализуйте структуру данных "очередь". Напишите программу, содержащую описание очереди и моделирующую работу...

Линейные структуры данных. Питон.Очередь с защитой от ошибок
Реализуйте структуру данных "очередь". Напишите программу, содержащую описание очереди и моделирующую работу очереди, реализовав все...

Задание с Сириус, "Очередь с защитой от ошибок" Не понимаю что от меня хочет местный проверщик заданий
Само задание: Очередь с защитой от ошибок Реализуйте структуру данных "очередь". Напишите программу, содержащую описание...

4
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
27.08.2022, 14:34
Pelemenb, посмотри и подумай
Python
1
2
3
g = [1, 2, 3, 4, 5, 1]
g.pop(g[0])
print(g)  # [1, 3, 4, 5, 1]   <-- пащщиму?
Это к слову о 14 строке
0
0 / 0 / 0
Регистрация: 27.08.2022
Сообщений: 2
28.08.2022, 05:16  [ТС]
я переделал, но все равно не проходит
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
g = []
logge = []
def log(msg):
    logge.append(msg)
while True:
    cm = input().split(' ')
    if (cm[0] == "push"):
        g.append(cm[1])
        log("ok")
    elif (cm[0] == "pop"):
        if(len(g) == 0): log("error")
        else:
            log(g[0])
            g.pop()
    elif (cm[0] == "front"):
        if(len(g) == 0): log("error")
        else: 
            log(g[0])
    elif (cm[0] == "size"): log(len(g))
    elif (cm[0] == "clear"):
        g.clear()
        log("ok")
    elif (cm[0] == "exit"):
        log("bye")
        break
for i in logge: print(i)
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
28.08.2022, 07:18
Цитата Сообщение от Pelemenb
переделал, но все равно
Продолжаем думать
Python
1
2
3
4
5
6
lst = [1,2,3,4,5]
print(lst)
lst.pop()
print(lst)
lst.pop(0)
print(lst)
0
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
28.08.2022, 12:36
Цитата Сообщение от Pelemenb Посмотреть сообщение
g.pop(g[0])
Цитата Сообщение от Pelemenb Посмотреть сообщение
но все равно не проходит
К гадалке не ходи, что удаление элемента из начала очереди должно работать за O(1). Кури collections.deque.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.08.2022, 12:36
Помогаю со студенческими работами здесь

Стек с защитой от ошибок
Язык Python Задача: Реализуйте структуру данных &quot;стек&quot;. Напишите программу, содержащую описание стека и моделирующую работу стека,...

Очередь с защитой от ошибок
2 задача Очередь с защитой от ошибок Реализуйте структуру данных &quot;очередь&quot;. Напишите программу, содержащую описание очереди и...

[Python] Дек с защитой от ошибок
Реализуйте структуру данных &quot;дек&quot;. Напишите программу, содержащую описание дека и моделирующую работу дека, реализовав все указанные здесь...

Очередь с защитой от ошибок
Очередь с защитой от ошибок Реализуйте структуру данных &quot;очередь&quot;. Напишите программу, содержащую описание очереди и моделирующую работу...

Очередь с защитой от ошибок
Помогите улучшить код. Реализуйте структуру данных &quot;очередь&quot;. Напишите программу, содержащую описание очереди и моделирующую работу...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю 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
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru