- 1、本文档共67页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五讲 栈;一、栈的概念和特性;栈的主要运算:;二、栈的存储结构;三、对栈的几种运算的实现方法:;(2)测试栈
测试栈顶指针的值,若top=0,则栈空;若top=n,则栈满。
(3)读栈
若top=0,则栈空,无栈顶元素可读,出错;若top0,则回送栈顶元素的值stack[top]。;(4)进栈(push)
将栈顶指针加1后,再把新元素送到栈顶。假设新元素x为整型,栈的最大深度为n,x和n设置为值型参。而栈和栈顶指针要设置成变量型参。
procedure push(var stack:arraytype; var top:integer;n:integer;x:integer);
begin
if top=n then
begin writeln(‘Stack full!’); halt end
else begin
top:=top+1; stack[top]:= x
end
end;;(5) 退栈(pop)
取得栈顶元素的值后,再把栈顶指针top减1。注意都用变量型参。
procedure pop(var stack:arraytype;var top:integer;var x:integer);
begin
if top=0 then
begin writeln(‘Stack empty!’); halt end
else begin x:=stack[top]; top:=top-1 end
end;;栈的记录方式实现方法;procedure push(var s:stack;x:integer);
begin
if s.top=n
then begin writeln(‘Stack full!’); halt end
else begin s.top:=s.top+1; s.data[s.top]:= x end
end;
procedure pop(var s:stack;var x:integer);
begin
if s.top=0
then begin writeln(‘Stack empty!’); halt end
else begin x:=s.data[s.top]; s.top:=s.top-1 end
end;;出栈有时也可用函数实现,如:
function pop(var s:stack):integer;
begin
if s.top=0
then begin writeln(‘Stack empty!’); halt end
else begin pop:=s.data[s.top]; s.top:=s.top-1
end
end;;练习;四、栈的应用;( 5-4-1.swf);算法 5. 1
Program p5_1(input,output);
type
stack=record
data:array[1..100] of integer;
top:0..100;
end;
var
n:integer; e:integer; s:stack; {对于输入的任意一个非负十进制整数
打印输出与其等值的八进制数}
begin
S.top=0; {构造空栈}
Readln(n); {输入一个十进制数}
while(n0)
begin
Push(s,n mod 8); {余数入栈}
n = n div 8; {非零商继续运算}
end
while (s.top0))
begin {和求余所得相逆的顺序输出八进制的各位数}
Pop(S,e);
print e;
end
end.;例5. 2:程序员输入问题
程序员输入程序,出现差错时可以采取以下的补救措施:敲错了一个键时,可以补敲一个退格符“#”,以表示前一个字符无效;发现当前一行有错,可以敲入一个退行符“@”,以表示“@”与前一个换行符之间的字符全部无效。
如:在终端上输
您可能关注的文档
最近下载
- DB63∕T 2387-2024 公路路基涎流冰防治技术指南.pdf
- 2025人教版英语四年级上册Unit 1 Helping at home单元测试试卷.pdf VIP
- 等比数列知识点总结与典型例题+答案.docx VIP
- 1、2024广西专业技术人员继续教育公需科目参考答案(98分).pdf VIP
- 配电运维题库题库(392道).docx VIP
- 中华优秀传统文化融入初中英语教学的路径探索.docx VIP
- 2025年生产安全应急演练方案(精选5篇).pdf VIP
- 2025安徽合肥高新区管委会直属国有企业公开招聘31人笔试历年参考题库附带答案详解.docx
- SY∕T 5329-2022 碎屑岩油藏注水水质指标技术要求及分析方法.pdf
- 电线、电缆载流量对照表.pdf VIP
文档评论(0)