#ifndef _MY_LINKSTACK_H_ #define _MY_LINKSTACK_H_ 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); #endif //_MY_LINKSTACK_H_
#define _CRT_SECURE_NO_WARNINGS #include <stdlib.h> #include <string.h> #include <stdio.h> #include "linkstack.h" #include "linklist.h" typedef struct _tag_LinkStack { LinkListNode node; void* item; }TLinkStack; //创建一个栈 相当于 创建一个线性表 LinkStack* LinkStack_Create() { return LinkList_Create(); } void LinkStack_Destroy(LinkStack* stack) { LinkStack_Clear(stack); //释放栈的 结点 LinkList_Destroy(stack); //释放句柄 } void LinkStack_Clear(LinkStack* stack) { while (LinkList_Length(stack) > 0) { LinkStack_Pop(stack); } return ; } //向栈中添加元素 相等向 线性表中 添加结点 int LinkStack_Push(LinkStack* stack, void* item) { int ret = 0; TLinkStack *tmp = NULL; //// void* item 栈结点 ===>链表结点 tmp = (TLinkStack *)malloc(sizeof(TLinkStack)); tmp->item = item; ret = LinkList_Insert(stack, (LinkListNode *)tmp, 0); if (ret != 0) { printf("func LinkList_Insert() err:%d \n", ret); free(tmp); return ret; } return ret; } //从栈中 弹出 元素 相当于 从线性表中 删除0号位置元素 void* LinkStack_Pop(LinkStack* stack) { TLinkStack *tmp = NULL; void *item = NULL; tmp = (TLinkStack*) LinkList_Delete(stack, 0); if (tmp == NULL) { printf("func LinkList_Delete() err \n"); return NULL; } //把链表节点 ====>转换成 栈结点 item = tmp->item; free(tmp); return item; } //获取栈顶元素 相等于 从线性表的0号位置元素 void* LinkStack_Top(LinkStack* stack) { TLinkStack *tmp = NULL; void *item = NULL; tmp = (TLinkStack *)LinkList_Get(stack, 0); if (tmp == NULL) { printf("func LinkStack_Top() err \n"); } item = tmp->item; return item; } int LinkStack_Size(LinkStack* stack) { return LinkList_Length(stack); }
#ifndef _MYLINKLIST_H_ #define _MYLINKLIST_H_ typedef void LinkList; /* typedef struct _tag_LinkListNode LinkListNode; struct _tag_LinkListNode { LinkListNode* next; }; */ typedef struct _tag_LinkListNode { struct _tag_LinkListNode* next; }LinkListNode; LinkList* LinkList_Create(); void LinkList_Destroy(LinkList* list); void LinkList_Clear(LinkList* list); int LinkList_Length(LinkList* list); int LinkList_Insert(LinkList* list, LinkListNode* node, int pos); LinkListNode* LinkList_Get(LinkList* list, int pos); LinkListNode* LinkList_Delete(LinkList* list, int pos); #endif
#define _CRT_SECURE_NO_WARNINGS #include <stdlib.h> #include <string.h> #include <stdio.h> #include "linklist.h" typedef struct _tag_LinkList { LinkListNode header; int length; }TLinkList; // LinkList* LinkList_Create() //O(1) { TLinkList *tmp = NULL; tmp = (TLinkList *)malloc(sizeof(TLinkList)); if (tmp == NULL) { printf("func LinkList_Create() err \n"); return NULL; } memset(tmp, 0, sizeof(TLinkList)); tmp->length = 0; tmp->header.next = NULL; // return tmp; } void LinkList_Destroy(LinkList* list) //O(1) { if (list == NULL) { return ; } free(list); return ; } void LinkList_Clear(LinkList* list) //O(1) { TLinkList *tList = NULL; tList = (TLinkList *)list; if (tList == NULL) { return ; } tList->header.next = NULL; tList->length = 0; return ; } int LinkList_Length(LinkList* list) //O(1) { TLinkList *tList = NULL; tList = (TLinkList *)list; if (tList == NULL) { return -1; } return tList->length; } int LinkList_Insert(LinkList* list, LinkListNode* node, int pos) //O(n) { int i = 0; LinkListNode *current = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list==NULL || node==NULL || pos<0) { return -1; } current = &(tList->header); for (i=0; i<pos; i++) { current = current->next; } //新结点 连接 后继链表 node->next = current->next; //前面的链表 连接 新结点 current->next = node; tList->length ++; return 0; } LinkListNode* LinkList_Get(LinkList* list, int pos) //O(n) { int i = 0; LinkListNode *current = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list==NULL || pos<0) { return NULL; } current = &(tList->header); //赋值指针变量初始化 for (i=0; i<pos; i++) { current = current->next; } return current->next; } LinkListNode* LinkList_Delete(LinkList* list, int pos) //O(n) { int i = 0; LinkListNode *current = NULL; LinkListNode *ret = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list==NULL || pos<0) { return NULL; } current = &(tList->header); for (i=0; i<pos; i++) { current = current->next; } ret = current->next; //缓存要删除的结点 current->next = ret->next; tList->length --; return ret; }
#define _CRT_SECURE_NO_WARNINGS #include <stdlib.h> #include <string.h> #include <stdio.h> #include "linkstack.h" void main() { LinkStack *stack = NULL; int a[5], i = 0; for (i=0; i<5; i++) { a[i] = i+1; } stack = LinkStack_Create(); //向栈中 添加 元素 for (i=0; i<5; i++) { LinkStack_Push(stack, &a[i]); //抛砖: 栈的结点a[i]==>转换成(适配成) 链表结点 ===>插入到链表库 } //栈的属性 printf("len:%d \n", LinkStack_Size(stack)); printf("top:%d \n", *( (int *)LinkStack_Top(stack) ) ); /* //元素 出栈 while (LinkStack_Size(stack) > 0 ) { int tmp = 0; tmp = *( (int *)LinkStack_Pop(stack) ); printf("%d ", tmp); } */ LinkStack_Destroy(stack); printf("hello...\n"); system("pause"); return ; }