新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
使用单链表来实现,push,pop均在链表头部进行
马尾网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、自适应网站建设等网站项目制作,到程序开发,运营维护。创新互联自2013年起到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联。
linkStack.h
#ifndef LINK_STACK_H
#define LINK_STACK_H
#include
#include
#include
#include
typedef void LinkStack;
LinkStack* LinkStack_Create();
void LinkStack_Destroy(LinkStack* stack);
void LinkStack_Clear(LinkStack* stack);
int LinkStack_Push(LinkStack* stack, void* item);
void* LinkStack_Pop(LinkStack* stack);
void* LinkStack_Top(LinkStack* stack);
int LinkStack_Size(LinkStack* stack);
bool LinkStack_isEmpty(LinkStack* stack);
#endif //LINK_STACK_H
linkStack.c
#include"linkStack.h"
#include"linkedList.h"
typedef struct NodeItem {
LinkedListNode node;
void* item;
}StackItem;
LinkStack* LinkStack_Create() {
return LinkedList_Create();
}
void LinkStack_Destroy(LinkStack* stack) {
LinkStack_Clear(stack);
LinkedList_Destory((LinkedList*)stack);
return;
}
void LinkStack_Clear(LinkStack* stack) {
if (stack == NULL) {
return;
}
while (LinkStack_Size(stack) > 0) {
LinkStack_Pop(stack);
}
}
int LinkStack_Push(LinkStack* stack, void* item) {
StackItem* element = (StackItem*)malloc(sizeof(StackItem));
element->node.next = NULL;
if (element == NULL) {
fprintf(stderr,"malloc memeory error.\n");
return - 1;
}
memset(element, 0, sizeof(StackItem));
element->item = item;
int ret = LinkedList_Insert((LinkedList*)stack, &element->node, 0);
if (ret != 0) {
fprintf(stderr,"LinkedList_Insert() error.\n");
if (element != NULL) {
free(element);
}
return -2;
}
return 0;
}
void* LinkStack_Pop(LinkStack* stack) {
if (stack == NULL) {
return NULL;
}
StackItem* element = (StackItem*)LinkedList_Delete((LinkedList*)stack, 0);
if (element == NULL) {
return NULL;
}
void* item = element->item;
free(element);
return item;
}
void* LinkStack_Top(LinkStack* stack) {
if (stack == NULL) {
return NULL;
}
StackItem* element = (StackItem*)LinkedList_Get((LinkedList*)stack, 0);
if (element == NULL) {
return NULL;
}
return element->item;
}
int LinkStack_Size(LinkStack* stack) {
if (stack == NULL) {
return 0;
}
return LinkedList_Length((LinkedList*)stack);
}
bool LinkStack_isEmpty(LinkStack* stack) {
return LinkStack_Size(stack) == 0;
}