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

抽象数据类型栈的定义

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
栈是限定仅在表尾进行插入或删除操作的线性表。因此,对栈来说,表尾端有其特殊含义,称为栈顶,相应地,表头端称为栈底。不含元素的空表称为空栈。3 e! O: {  `" ?( H; I
假设栈S=(a1,…,ai-1,ai,…,an),则a1为栈底元素,an为栈顶元素。栈中元素按a1,a2,…,an的次序进栈,退栈的第一个元素应为栈顶元素。换句话说,栈的修改是按后进先出的原则进行的。因此,栈又称为后进先出的线性表。
. W- w3 E8 J6 m* E栈的基本操作除了在栈顶进行插入或删除外,还有栈的初始化、判空及取栈顶元素等。下面给出栈的抽象数据数据类型的定义:; j2 X* C$ G, i0 }8 x) y
ADT Stack{3 c( D7 t6 i1 u2 _: g& |$ [2 K0 X
数据对象:D={ai|ai€ElemSet,i=1,2,…,n,n≥0}" H: m* J9 Q! r! Q/ X9 L( e
数据关系:R1={<ai-1,ai>|ai-1,ai€D,i=2,…,n}
" o2 j1 U/ ?% M, j约定an端为栈顶,a1端为栈底。2 I9 x. J# A2 u$ d
基本操作:! e# a7 ?  q$ R2 x) }% E/ z( Y
InitStack(&s)
1 o9 `+ {1 m6 f9 ~操作结果:构造一个空栈S。
3 c, ~& \3 [" U( i6 _9 |' Y) QDestroyStack(&S)
: s9 T0 A9 h3 n. i! b) W初始条件:栈S已存在。4 e$ z- P6 l5 q6 w
操作结果:栈S被销毁。
* f& T  b7 Z( Y' l; A1 I* dClearStack(&S)7 m# X/ W5 p: |; M
初始条件:栈S已存在。& t1 N( K: P5 i! ]8 H* q* ]
操作结果:栈S被清为空栈。6 \7 D1 P% \" r5 `
StackEmpty(S)
# Q1 ^6 t1 p7 |3 f初始条件:栈S已存在。7 `; m6 p0 Q. H. C+ x. R( e& D
操作结果:若栈为空栈,则返回TURE,否则FALSE。$ e. L4 |6 e  w/ E# F$ G- U3 w% h
StackLength(S)
6 W/ w; u) d7 d) E3 b; ~% G# r初始条件:栈S已存在。
  n8 k$ M- z0 E操作结果:返回S的元素个数,即栈的长度。+ ]* {9 g. |- e6 R
GetTop(S,&e)$ S7 q/ i) _0 k# K1 }
初始条件:栈S已存在且非空。
! z! y, E7 O8 u4 g$ h8 ^! t操作结果:用e返回S的栈顶元素。
# v$ G: ?7 }/ Z, N3 gPush(S,&e)
4 V# ]& }3 J( p' Q4 r4 z初始条件:栈S已存在。
- ~5 R2 U3 \4 j1 s4 |0 u( x. _操作结果:插入新的元素e为新的栈顶元素。; \1 `# g9 s9 X6 O# {
Pop(&S,&e)) {) ^7 r" R0 Z  p
初始条件:栈S已存在且非空。
4 h/ h- T, W# f5 O; F, Z操作结果:删除S的栈顶元素,并用e返回其值。
  y1 C# ^0 u# {  V" ]; a" MStackTraverse(S,visit())- T9 L6 _9 i0 z: k+ R& _2 W
初始条件:栈S已存在且非空。3 \& g+ y7 Y, y$ H: R4 `+ ]  c
操作结果:从栈底到栈顶依次对S的每个数据元素调用函数visit()。一旦visit()失败,则操作失效。
! w7 Z3 S  j1 ~! B" S' c}ADT Stack

该用户从未签到

9#
发表于 2016-8-16 10:38 | 只看该作者
谢谢楼主,一步步来,学习中……
' G; k& l& x( a

该用户从未签到

8#
发表于 2016-8-15 15:53 | 只看该作者
好人啊 感恩感恩4 K- B7 O, M. r/ ?/ I: R$ L

该用户从未签到

5#
发表于 2016-8-13 10:43 | 只看该作者
谢谢分享,必须赞一个~* x! d! D* X$ s5 e0 u  e

该用户从未签到

3#
发表于 2016-8-12 10:50 | 只看该作者
谢谢分享,必须赞一个~. Z* |7 n1 M. w. M5 Y0 `

该用户从未签到

2#
发表于 2016-8-11 14:29 | 只看该作者
谢谢分享,必须赞一个~
) i0 X2 e4 @* Z( T+ t/ r
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-25 01:25 , Processed in 0.156250 second(s), 24 queries , Gzip On.

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

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

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