好学IT学院:IT信息技术分享交流平台
来源:www.easyde.net  作者:本站整理  发布时间:2006-11-15  ★★★加入收藏〗〖手机版
摘要:本课主题:栈的表示与实现 教学目的:栈的数据类型定义、栈的顺序存储表示与实现 教学重点:栈的顺序存储表示与实现方法 教学难点:栈的定义…

typedef struct STACK Sqstack;
Status InitStack(SqStack &S);
Status DestroyStack(SqStack &S);
Status ClearStack(SqStack &S);
Status StackEmpty(SqStack S);
int StackLength(SqStack S);
Status GetTop(SqStack S,SElemType &e);
Status Push(SqStack &S,SElemType e);
Status Pop(SqStack &S,SElemType &e);
Status StackTraverse(SqStack S,Status (*visit)());
Status InitStack(SqStack &S) {
S.base=(SelemType *)malloc(STACK_INIT_SIZE *sizeof(ElemType));
if(!S.base)exit(OVERFLOW);
S.top=S.base;
S.stacksize=STACK_INI_SIZE;
return OK;
}//IniStack

Status DestroyStack(SqStack &S); {
}//DestroyStack

Status ClearStack(SqStack &S); {
S.top=S.base;
} //ClearStack

Status StackEmpty(SqStack S); {
if(S.top==S.base) return TRUE;
else return FALSE;
} //StackEmpty

int StackLength(SqStack S); {
int i; SElemType *p;
i=0;
p=S.top;
while(p!=S.base) {p++; i++; }
} //stackLength

Status GetTop(SqStack S,SElemType &e); {
if(S.top==S.base) return ERROR;
e=*(S.top-1);
return OK;
} //GetTop

Status Push(SqStack &S,SElemType e); {
if(S.top - s.base>=S.stacksize) {
S.base=(ElemType *) realloc(S.base,
(S.stacksize + STACKINCREMENT) * sizeof(ElemType));
if(!S.base)exit(OVERFLOW);
S.top=S.base+S.stacksize;
S.stacksize+=STACKINCREMENT;
}
*S.top++=e;
return OK;
} //Push

Status Pop(SqStack &S,SElemType &e); {
if(S.top==S.base)
return ERROR;
e=*--S.top;
return OK;
}//Pop

Status StackTraverse(SqStack S,Status (*visit)()); {
}//StackTraverse

以上伪代码的C语言源码

三、总结

栈的定义
栈的顺序存储实现

数据结构教程(九)—循环链表与双向链表
  本课主题:循环链表与双向链表教学目的:掌握循环链表的概念,掌握双向链表的的表示与实现教学重点:双向链表的表示与实现教学难点:双向链…
  • 好学触屏公众号虎力全开、杨帆起航!
  • 好学考试H5触屏版开放内测