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

抽象数据类型栈的定义

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
栈是限定仅在表尾进行插入或删除操作的线性表。因此,对栈来说,表尾端有其特殊含义,称为栈顶,相应地,表头端称为栈底。不含元素的空表称为空栈。
, N. h( ]& h- v0 P# c4 R$ j) Z! o假设栈S=(a1,…,ai-1,ai,…,an),则a1为栈底元素,an为栈顶元素。栈中元素按a1,a2,…,an的次序进栈,退栈的第一个元素应为栈顶元素。换句话说,栈的修改是按后进先出的原则进行的。因此,栈又称为后进先出的线性表。  V. k- O) T- Q/ [+ g5 E4 T$ R
栈的基本操作除了在栈顶进行插入或删除外,还有栈的初始化、判空及取栈顶元素等。下面给出栈的抽象数据数据类型的定义:( |( b* d7 d9 r
ADT Stack{
( m( |- v9 [' ^数据对象:D={ai|ai€ElemSet,i=1,2,…,n,n≥0}' |$ _# y5 \6 c# N
数据关系:R1={<ai-1,ai>|ai-1,ai€D,i=2,…,n}
, L: ?1 l) U# `" r4 \约定an端为栈顶,a1端为栈底。
7 ]* s+ s+ S8 n基本操作:, c$ E3 p- `/ h- ?' p9 k: A3 z( k7 [
InitStack(&s)
1 k1 u& t+ a9 N$ t( O操作结果:构造一个空栈S。
0 T3 Q' A2 [: ?+ ]* UDestroyStack(&S)
  c2 x+ K# {% E. z/ D初始条件:栈S已存在。
% J& m: |) [4 o8 R" t操作结果:栈S被销毁。
# N8 y0 b4 u3 x1 p6 W0 oClearStack(&S); l& I% V7 [+ C9 f6 y: O" r
初始条件:栈S已存在。1 ~% Y, t/ [. H+ j! N3 Z0 C
操作结果:栈S被清为空栈。* v, u8 E; s3 k$ b: s
StackEmpty(S)
- T$ z" X( E9 `/ A$ o; b初始条件:栈S已存在。6 U5 m- K9 ], C: n; _' |
操作结果:若栈为空栈,则返回TURE,否则FALSE。6 S4 N1 F, l9 g$ |
StackLength(S)
+ [+ H3 T/ N. u2 N' n! ]初始条件:栈S已存在。
( h' r( e1 M$ s9 R4 L4 n! a: ~操作结果:返回S的元素个数,即栈的长度。. w5 z+ g, t+ v8 e) G3 O# R1 a3 {' N
GetTop(S,&e)
( o- T" C  O( `0 j  E) Y6 n初始条件:栈S已存在且非空。
& |% ]: Y( S$ M$ E& s+ m操作结果:用e返回S的栈顶元素。
) i% L5 G! r$ ]% g9 b' s  XPush(S,&e)
4 K2 }* g- q$ t. {初始条件:栈S已存在。1 v5 B3 o  D, ?$ a: C/ d
操作结果:插入新的元素e为新的栈顶元素。
" `2 K6 O& V5 P6 DPop(&S,&e)
  S. g1 ~5 _" ]初始条件:栈S已存在且非空。
* b' m5 X; k7 V! H操作结果:删除S的栈顶元素,并用e返回其值。
4 n7 N6 i: s! Y" |9 e' y. yStackTraverse(S,visit())
: z& j- l) e# j# n* v' ?2 g初始条件:栈S已存在且非空。" d2 t! w% @4 R) e3 h, p
操作结果:从栈底到栈顶依次对S的每个数据元素调用函数visit()。一旦visit()失败,则操作失效。
7 Z, m+ U  i, R}ADT Stack

该用户从未签到

2#
发表于 2016-8-11 14:29 | 只看该作者
谢谢分享,必须赞一个~7 p- C& f: l/ h1 j- D1 E- m

该用户从未签到

3#
发表于 2016-8-12 10:50 | 只看该作者
谢谢分享,必须赞一个~2 L% ^! X% Y- v

该用户从未签到

5#
发表于 2016-8-13 10:43 | 只看该作者
谢谢分享,必须赞一个~$ Z6 ~! K3 ~' R

该用户从未签到

8#
发表于 2016-8-15 15:53 | 只看该作者
好人啊 感恩感恩
; `, R( M; j% H: c' ~" ]

该用户从未签到

9#
发表于 2016-8-16 10:38 | 只看该作者
谢谢楼主,一步步来,学习中……
$ t( z6 e0 Q& ?' D' y$ |
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-25 00:53 , Processed in 0.171875 second(s), 23 queries , Gzip On.

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

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

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