Non-destructive stack#reverse.
This commit is contained in:
10
lib/stack.c
10
lib/stack.c
@@ -95,17 +95,17 @@ struct stack *pop(struct stack **stack) {
|
||||
return(popped_entry);
|
||||
}
|
||||
|
||||
struct stack *reverse(struct stack **stack) {
|
||||
if (length(*stack) > 1) {
|
||||
struct stack *reverse(struct stack *stack) {
|
||||
if (length(stack) > 1) {
|
||||
struct stack *tmp_stack;
|
||||
|
||||
allocate_stack(&tmp_stack);
|
||||
initialize_stack(tmp_stack);
|
||||
while (!empty(*stack)) {
|
||||
push(&tmp_stack, pop((stack))->card);
|
||||
while (!empty(stack)) {
|
||||
push(&tmp_stack, pop((&stack))->card);
|
||||
}
|
||||
return(tmp_stack);
|
||||
} else {
|
||||
return(*stack);
|
||||
return(stack);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -17,6 +17,6 @@ bool empty(struct stack *);
|
||||
int length(struct stack *);
|
||||
void push(struct stack **, struct card *);
|
||||
struct stack *pop(struct stack **);
|
||||
struct stack *reverse(struct stack **);
|
||||
struct stack *reverse(struct stack *);
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user