找回密码
 注册
关于网站域名变更的通知
查看: 477|回复: 10
打印 上一主题 下一主题

抽象数据类型栈的定义

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2016-8-11 14:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
栈是限定仅在表尾进行插入或删除操作的线性表。因此,对栈来说,表尾端有其特殊含义,称为栈顶,相应地,表头端称为栈底。不含元素的空表称为空栈。
/ S6 k. N, ?5 W! L假设栈S=(a1,…,ai-1,ai,…,an),则a1为栈底元素,an为栈顶元素。栈中元素按a1,a2,…,an的次序进栈,退栈的第一个元素应为栈顶元素。换句话说,栈的修改是按后进先出的原则进行的。因此,栈又称为后进先出的线性表。
; ^; y! d7 {3 i  T7 Y; b0 |2 ~栈的基本操作除了在栈顶进行插入或删除外,还有栈的初始化、判空及取栈顶元素等。下面给出栈的抽象数据数据类型的定义:6 y$ L: r, F5 A" {! N
ADT Stack{
1 y5 Y$ s. \) |4 L! Z9 e数据对象:D={ai|ai€ElemSet,i=1,2,…,n,n≥0}
# k2 a# T+ v, K数据关系:R1={<ai-1,ai>|ai-1,ai€D,i=2,…,n}
- a4 k2 F# J0 z- T/ a, W7 y# }* h6 T约定an端为栈顶,a1端为栈底。/ l" b; ?  o  X$ V$ k" D
基本操作:9 }# m4 ^. f) I8 k9 C
InitStack(&s)  U4 l0 d( u& Z
操作结果:构造一个空栈S。5 S+ x) L: X2 k
DestroyStack(&S)1 s4 c" I/ o$ F2 f; O
初始条件:栈S已存在。
" }1 p% [) Q2 n# D操作结果:栈S被销毁。* j# ]1 w5 ?6 v3 Z9 U
ClearStack(&S); |" y/ h, Y* v0 U% G, _2 t
初始条件:栈S已存在。9 F2 w* l' x+ L; t% v7 Y1 N  z
操作结果:栈S被清为空栈。& X6 Z, [5 U! s5 R3 S, e* C4 Y
StackEmpty(S)
" V0 X( `  T4 E7 X. ]  Y) x4 y初始条件:栈S已存在。
  N# U* y9 H0 K, V" C2 |操作结果:若栈为空栈,则返回TURE,否则FALSE。
% ]) X9 _* u+ Q) p& [+ l# M. LStackLength(S)  F# m* M: O, }: Y9 N
初始条件:栈S已存在。" q4 [4 |7 ]1 K
操作结果:返回S的元素个数,即栈的长度。
; b/ k9 e7 o1 h6 u; Z0 T; CGetTop(S,&e)& q: r/ M- R: V: |$ h8 g
初始条件:栈S已存在且非空。
0 d: ]$ q) h: d; h操作结果:用e返回S的栈顶元素。( u# g3 w: B' [( i, P8 ]; N, v7 R
Push(S,&e)( I" b* @+ s/ L
初始条件:栈S已存在。1 `: f4 X0 F2 q8 t+ s7 B
操作结果:插入新的元素e为新的栈顶元素。# ?. W/ |$ m6 j  _
Pop(&S,&e)
) X" h, N' K/ ~1 u+ w( k0 {# F. N) Q9 B初始条件:栈S已存在且非空。
5 T6 j: h; y7 ~" {3 C& w9 o/ I操作结果:删除S的栈顶元素,并用e返回其值。2 a, b  K; T% S2 J  E) E( l0 W
StackTraverse(S,visit())6 Q) \5 y3 D& H3 t1 w% j8 v
初始条件:栈S已存在且非空。) y6 M2 a; n1 D7 |5 ?. B  a' i1 i
操作结果:从栈底到栈顶依次对S的每个数据元素调用函数visit()。一旦visit()失败,则操作失效。
7 X. {# g+ D1 ~5 j. Q}ADT Stack

该用户从未签到

2#
发表于 2016-8-11 14:29 | 只看该作者
谢谢分享,必须赞一个~  t' _8 u9 ?' `

该用户从未签到

3#
发表于 2016-8-12 10:50 | 只看该作者
谢谢分享,必须赞一个~: l+ Y% ^, ]1 \9 P0 E

该用户从未签到

5#
发表于 2016-8-13 10:43 | 只看该作者
谢谢分享,必须赞一个~" @5 d, }/ f2 V: d. a# [1 ?. T

该用户从未签到

8#
发表于 2016-8-15 15:53 | 只看该作者
好人啊 感恩感恩' \  S. ?) T/ l* V

该用户从未签到

9#
发表于 2016-8-16 10:38 | 只看该作者
谢谢楼主,一步步来,学习中……
  B) [& H0 \( F2 U& _9 h) X* d
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-24 23:57 , Processed in 0.140625 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表