Задача:
Реализуйте структуру данных «дек«. Напишите программу, содержащую описание дека и моделирующую работу дека, реализовав все указанные здесь методы. Программа считывает последовательность команд и в зависимости от команды выполняет ту или иную операцию. После выполнения каждой команды программа должна вывести одну строчку. Возможные команды для программы:
push_front
Добавить (положить) в начало дека новый элемент. Программа должна вывести ok.
push_back
Добавить (положить) в конец дека новый элемент. Программа должна вывести ok.
pop_front
Извлечь из дека первый элемент. Программа должна вывести его значение.
pop_back
Извлечь из дека последний элемент. Программа должна вывести его значение.
front
Узнать значение первого элемента (не удаляя его). Программа должна вывести его значение.
back
Узнать значение последнего элемента (не удаляя его). Программа должна вывести его значение.
size
Вывести количество элементов в деке.
clear
Очистить дек (удалить из него все элементы) и вывести ok.
exit
Программа должна вывести bye и завершить работу.
Гарантируется, что количество элементов в деке в любой момент не превосходит 100. Перед исполнением операций pop_front,pop_back, front, back программа должна проверять, содержится ли в деке хотя бы один элемент. Если во входных данных встречается операция pop_front, pop_back, front, back, и при этом дек пуст, то программа должна вместо числового значения вывести строку error.
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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
#include <iostream> #include <string> using namespace std; struct stack{ int storage[1000]; int end=0; int sizze=0; int start=1; int lol=100; int push_back(int x){ end = (end + 1)%lol; storage[end] = x; sizze++; } int push_front(int x){start = (start - 1+lol)%lol; storage[start] = x; sizze++;} void pop_back(){end = (end - 1+lol)%lol; sizze--;} void pop_front(){start = (start + 1)%lol; sizze--;} int back() const{return storage[end];} int size() const{return sizze;} void clear(){end = 0; sizze = 0; start = 1; } int front() const{ return storage[start]; } }; int main() { stack storage; string s; int n; while(cin >> s){ if(s == "push_back"){ cin >> n; storage.push_back(n); cout << "ok\n"; }else if(s == "push_front"){ cin >> n; storage.push_front(n); cout << "ok\n"; } else if(s == "pop_back"){ if(storage.size()){ cout << storage.back() << endl; storage.pop_back(); }else{ cout << "error\n"; } }else if(s == "pop_front"){ if(storage.size()){ cout << storage.front() << endl; storage.pop_front(); }else{ cout << "error\n"; } }else if(s == "front"){ if(storage.size()){ cout << storage.front() << endl; } else{ cout << "error\n"; } } else if(s == "back"){ if(storage.size()){ cout << storage.back() << endl; }else{ cout << "error\n"; } }else if(s == "size"){ cout << storage.size() << endl; }else if(s == "clear"){ storage.clear(); cout << "ok\n"; }else if(s == "exit"){ cout << "bye\n"; return 0; } } return 0; } |
Решенная задача на e-olimp
Код на ideone
Решение хорошее, но его нужно правильно оформить, сделать правильные отступы. Перечитайте, пожалуйста, Как делать домашние задания.
Пока оценка чисто символическая.