- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3.1 栈 ( Stack )
3.1.1 栈的定义及运算;只允许在一端插入和删除的顺序表
允许插入和删除
的一端称为栈顶 (top),
另一端称为栈底(bottom)
特点
后进先出 (LIFO);例:对于一个栈,给出输入项A、B、C,如果输入项序列由A B C组成,试给出所有可能的输出序列。;栈的顺序存储结构; 设s是SeqStack类型的指针变量。
s–data[0]是栈底元素
进栈时需将s–top加1,退栈时需将s–top 减1; 当栈满时再做进栈运算必定产生空间溢出,简称“上溢”
当栈空时再做退栈运算也将产生溢出,简称“下溢”。;进出栈示例;栈的基本操作;(1)InitStack(s)
初始化:初始化一个新的栈。
(2)StackEmpty(s)
栈空判断:若栈s空,则返回TRUE;
(3)Push(s,x)
入栈:在栈s的顶部插入元素x,若栈满,则返回FALSE;
(4)Pop(s)
出栈:若栈s不空,则返回栈顶元素,并从栈顶中删除该元素;否则,返回空元素NULL。
(5)GetTop(s,x)
取栈元素:若栈s不空,则返回栈顶元素;;void InitStack(SeqStack *s)
{s-top=-1;}
置空栈
void ClearStack(SeqStack *s)
{ s-top=-1; };int Push(SeqStack *s,DataType x)
{
{
s-top++;
s-data[s-top]=x;
}
return 1;
};DataType Pop(SeqStack *s)
{ DataType x
{ x= s-data[s-top];
s-top--;
return(x);
}
};DataType GetTop(SeqStack *s, DataType x)
{
x= s-data[s-top];
return(x);
};3.2 栈的应用举例
由于栈结构具有的后进先出的固有特性,致使栈成为程序设计中常用的工具。以下是几个栈应用的例子。
;3.2.1 数制转换
十进制N和其它进制数的转换是计算机实现计算的基本问题,其解决方法很多。; n n div 8 n mod 8
1348 168 4
168 21 0
21 2 5
2 0 2
;数制转换算法:
void conversion( ) { InitStack(s); //建空栈 scanf(“%d”,x); //输入一个非负十进制整数 while(x!=0) { // x不等于零 循环 push(s, x% 8); // x/8第一个余数进栈
x=x/8; //整除运算
} while(! StackEmpty(s) )
{ x=pop(s); printf(“%d”,x); //依次输出栈顶元素
}} ;3.2.4中缀表达式求值;算符优先关系表
表达式中任何相邻运算符c1、c2的优先关系有: c1c2:c1的优先级低于c2 c1=c2:c1的优先级等于c2 c1c2:c1的优先级高于c2;读出一个符号后,作如下处理:
(1)是操作数:
将其压入操作数栈,读下一个符号。;(2)是运算符:;3)假如读出的是“)”,则:
A)若运算符栈栈顶不是“(”,连续退出两操作数,退出一个运算符,作相应的运算,将结果压操作数栈,然后继续执行A
B)若运算符栈栈顶为“(”,则消去括号,依次读下一个符号;?int express ( )
{ //运算数栈,OP为运算符集合。
InitStack(OPTR); Push (OPTR, ‘# ‘);
InitStack(OPND); c=getchar( );;续
您可能关注的文档
最近下载
- 神经系统的分级调节ppt课件.pptx VIP
- AI测试练习试题及答案.doc
- 2025广西南宁江南区“点对点”送工和乡村公岗专管员招聘2人备考练习题库及答案解析.docx VIP
- 肿瘤防治策略与最新进展.docx VIP
- 第五章植物-病原互作过程中效应子的作用.ppt VIP
- 湘科版《科学》四年级上册全册教案.doc VIP
- IEC_62893-4-1-2020 额定电压不超过 0.61 KV 的电动汽车充电电缆 – 第 4-1 部分:符合 IEC 61851‑‑1 模式 4 的直流充电电缆 – 不使用热管理系统的直流充电.pdf VIP
- 机器人集成解决方案 (机器人+).pdf VIP
- 消除艾滋病、梅毒和乙肝母婴传播项目工作制度及流程(模板).pdf
- 2025广西南宁市江南区“点对点”送工和乡村公岗专管员招聘考试备考试题及答案解析.docx VIP
文档评论(0)