链栈相关

This commit is contained in:
Xu Bai
2019-07-01 22:12:37 +08:00
parent 12553c0b9e
commit 8f33af4fc2
3 changed files with 109 additions and 1 deletions

View File

@@ -140,5 +140,6 @@ int main()
printf("栈顶元素 e=%d 栈的长度为%d\n",e,StackLength(s));
ClearStack(&s);
printf("清空栈后,栈空否:%d(1:空 0:否)\n",StackEmpty(s));
getchar();
return 0;
}

View File

@@ -2,7 +2,7 @@
* @Author: Xu Bai
* @Date: 2019-07-01 21:32:41
* @LastEditors: Xu Bai
* @LastEditTime: 2019-07-01 21:39:07
* @LastEditTime: 2019-07-01 22:12:36
*/
#include "stdio.h"
#include "stdlib.h"
@@ -46,3 +46,110 @@ Status InitStack(LinkStack *S)
S->count = 0;
return OK;
}
Status ClearStack(LinkStack *S)
{
LinkStackPtr p, q;
p = S->top;
while (p)
{
q = p;
p = p->next;
free(q);
}
S->count = 0;
return OK;
}
Status StackEmpty(LinkStack S)
{
if (S.count == 0)
{
return TRUE;
}
else
{
return FALSE;
}
}
int StackLength(LinkStack S)
{
return S.count;
}
Status GetTop(LinkStack S, ElemType *e)
{
LinkStackPtr p;
if (S.top == NULL)
{
return ERROR;
}
else
{
*e = S.top->data;
}
return OK;
}
Status Push(LinkStack *S, ElemType e)
{
LinkStackPtr s = (LinkStackPtr)malloc(sizeof(StackNode));
s->data = e;
s->next = S->top;
S->top = s;
S->count++;
return OK;
}
Status Pop(LinkStack *S, ElemType *e)
{
if (StackEmpty(*S))
{
return ERROR;
}
LinkStackPtr p;
*e = S->top->data;
p = S->top->next;
S->top->next = p->next;
free(p);
S->count--;
return OK;
}
Status StackTraverse(LinkStack S)
{
LinkStackPtr p;
p = S.top;
while (p)
{
visit(p->data);
p = p->next;
}
printf("\n");
return OK;
}
int main()
{
LinkStack s;
ElemType e;
InitStack(&s);
int i;
for (i = 1; i <= 10; i++)
{
Push(&s, i);
}
printf("Traverse:\n");
StackTraverse(s);
Pop(&s, &e);
printf("pop:\n");
StackTraverse(s);
printf("the elem:%d\n", e);
ClearStack(&s);
printf("clear!");
StackTraverse(s);
getchar();
return OK;
}

BIN
a.out

Binary file not shown.