List.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. #include <iostream>
  2. #include <any>
  3. template <typename T>
  4. struct Node
  5. {
  6. T value;
  7. Node<T>* next = nullptr;
  8. Node<T>* prev = nullptr;
  9. };
  10. template <typename T>
  11. class List
  12. {
  13. protected:
  14. Node<T>* start = nullptr;
  15. Node<T>* end = nullptr;
  16. Node<T>* getNode(int index)
  17. {
  18. if (index >= lenght)
  19. throw "index > lenght";
  20. Node<T>* currentNode = start;
  21. for(int i = 0; i < index; i++) {
  22. currentNode = currentNode->next;
  23. }
  24. return currentNode;
  25. }
  26. public:
  27. int lenght;
  28. List()
  29. {
  30. Node<T>* start = nullptr;
  31. Node<T>* end = nullptr;
  32. lenght = 1;
  33. }
  34. ~List()
  35. {
  36. Node<T>* currentNode = start;
  37. if (currentNode == nullptr) return;
  38. while (currentNode->next!=nullptr)
  39. {
  40. currentNode = currentNode->next;
  41. delete currentNode->prev;
  42. }
  43. delete currentNode;
  44. }
  45. virtual void add(T value)
  46. {
  47. Node<T>* node = new Node<T>;
  48. node->value = value;
  49. if(start==nullptr) {
  50. start = node;
  51. end = node;
  52. return;
  53. }
  54. node->prev = end;
  55. end->next = node;
  56. end = node;
  57. lenght++;
  58. }
  59. virtual void add(T value, int index)
  60. {
  61. Node<T>* node = new Node<T>;
  62. node->value = value;
  63. Node<T>* before = getNode(index-1);
  64. node->next = before->next;
  65. node->prev = before;
  66. node->next->prev = node;
  67. before->next = node;
  68. lenght++;
  69. }
  70. virtual T pop()
  71. {
  72. T result = end->value;
  73. if (end == start) {
  74. end = nullptr;
  75. start = nullptr;
  76. lenght--;
  77. return result;
  78. }
  79. end = end->prev;
  80. end->next = nullptr;
  81. lenght--;
  82. return result;
  83. }
  84. virtual T pop(Node<T>* node)
  85. {
  86. node->next->prev = node->prev;
  87. node->prev->next = node->next;
  88. lenght--;
  89. return node->value;
  90. }
  91. virtual T pop(int index)
  92. {
  93. T result;
  94. if (index==0) {
  95. result = start->value;
  96. start = getNode(index+1);
  97. lenght--;
  98. }
  99. if (index>=lenght-1) {
  100. result = pop();
  101. }
  102. Node<T>* node = getNode(index);
  103. result = pop(node);
  104. return result;
  105. }
  106. T operator[](int index)
  107. {
  108. return getNode(index)->value;
  109. }
  110. friend std::ostream &operator <<(std::ostream &os, List &c)
  111. {
  112. os << "( ";
  113. Node<T>* currentNode = c.start;
  114. while (currentNode->next!=nullptr)
  115. {
  116. os << currentNode->value << " = ";
  117. currentNode = currentNode->next;
  118. }
  119. os << currentNode->value << " )";
  120. return os;
  121. }
  122. };