stack.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. #include <stdlib.h>
  2. #include "rubiks.h"
  3. t_stack *stack_create()
  4. {
  5. t_stack *result = (t_stack *)malloc(sizeof(*result));
  6. result->items = NULL;
  7. result->count = 0;
  8. return result;
  9. }
  10. t_stack *stack_copy(const t_stack *t)
  11. {
  12. t_stack *result = (t_stack *)malloc(sizeof(*result));
  13. struct s_stackitem *aitem, *bitem;
  14. size_t i;
  15. result->items = NULL;
  16. result->count = t->count;
  17. if (result->count)
  18. {
  19. aitem = malloc(sizeof(*aitem));
  20. bitem = t->items;
  21. aitem->value = bitem->value;
  22. result->items = aitem;
  23. for (i =1; i < t->count; ++i)
  24. {
  25. aitem->prev = malloc(sizeof(*aitem));
  26. aitem = aitem->prev;
  27. bitem = bitem->prev;
  28. aitem->prev = NULL;
  29. aitem->value = bitem->value;
  30. }
  31. }
  32. return result;
  33. }
  34. int stack_pop(t_stack *s)
  35. {
  36. int r;
  37. struct s_stackitem *oldNode = s->items;
  38. if (!s->count)
  39. return -1;
  40. oldNode = s->items;
  41. r = oldNode->value;
  42. s->items = oldNode->prev;
  43. s->count--;
  44. free(oldNode);
  45. return r;
  46. }
  47. size_t stack_length(const t_stack *s)
  48. {
  49. return s->count;
  50. }
  51. int stack_value(const t_stack *s)
  52. {
  53. if (!s->count)
  54. return -1;
  55. return s->items->value;
  56. }
  57. void stack_destroy(t_stack *stack)
  58. {
  59. if (!stack)
  60. return;
  61. while (stack->count)
  62. stack_pop(stack);
  63. free(stack);
  64. }
  65. void stack_push(t_stack *st, int v)
  66. {
  67. struct s_stackitem *s = (struct s_stackitem *) malloc(sizeof(*s));
  68. s->prev = st->count ? st->items : NULL;
  69. s->value = v;
  70. st->items = s;
  71. st->count++;
  72. }