- 1、本文档共48页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构-栈 程序=数据结构+算法 对于程序设计来说: 编程语言是工具; 数据结构是基础; 算法设计是方法。 数据结构 数据结构相关概念 数据(data) 计算机科学中指所有能输入到计算机中并被程序处理的符号总称。例如数值、字符、图像、声音都属于数据的范畴。 数据元素(data element) 是数据的基本单位 ,在程序中作为一个整体进行考虑。 有时一个数据元素有若干数据项。 数据对象(data object)是性质相同的数据元素的集合,是数据的一个子集。 逻辑结构 物理结构 线性表 线性表的两种存储方式 1、顺序存储结构 顺序存储结构是指用一组地址连续的存贮单元依次存储线性表的元素,通常用数组实现。数组的物理实现是一块连续的存储空间,它是按首址(表中第1个元素的地址)十位移来访问每一个元素。 链表的插入与删除 线性表的具体实现 顺序存储结构 用数组类型: list: array [1..maxlen] of elemtp; 链式存储结构 用指针类型 和 动态变量: pointer = nodetype ^ ; nodetype = record data : elemtp ; next : pointer ; end; 顺序存储与链式存储操作的对比 栈 通常栈可以用顺序的方式存储(数组),分配一块连续的存储区域存放栈中的表目,并用一个变量t指向当前栈顶(如下图)。 栈的实现(一) 栈的实现(二) const m=栈表目数的上限; type stack=record elem: array[1..m] of elemtp; top:0..m; {栈顶指针} end; Var s:stack;{栈} 栈的基本操作 栈的基本操作包括四种 初始化(init)、 进栈(push)、 出栈(pop)、 读取栈顶元素(top)。 1) 过程init(s,t) —初始化 procedure init; begin t:=0; end; 2)、过程push(x)—往栈s中压入一个值为x的数据: procedure push (var s:stack; x:stype; var t:integer); begin if t=m then writeln(‘overflow’) {上溢} else begin t←t+1;s[t]←x;end;{else} {x入栈} end;{Push} 3)函数pop(s,t)—从栈中弹出一个表目 function pop (var s:stack; var t:integer):stype; begin if t=0 then writeln (‘underflow’) {下溢} else begin pop←s[t]; t←t-1; end;{else} {栈顶元素出栈} end;{pop} 4)函数top(s,t)—读栈顶元素 function top (s:stack; t:integer):stype; begin if t=0 then writeln (‘stack empty’) else top←s[t]; {返回栈顶元素} end;{top} 栈的应用 1、(1998) 栈S初始状态为空,现有5个元素组成的序列{1,2,3,4,5},对该序列在栈S上一次进行如下操作(从序列中的1开始,出栈后不再进栈):进栈、进栈、进栈、出栈、进栈、出栈、进栈。问出栈的元素序列是______ (A) {5,4,3,2,1} (B) {2,1} (C) {2,3} (D) {3,4} 栈的应用3——表达式求值 输入一个表达式,该表达式含有“+”、“-”、“*”、“/”、“(”、“)”和操作数 输入以‘@’结束。输出该表达式的值。 分析: 由于一个表达式含操作数、运算符和括号,因此只能采用字符串类型输入,而字符是不能进行数值计算的。在这种情况下,计算机又如何计算表达式的值呢。一般方法是: 中缀表达式→等价的后缀表达式→计算后缀表达式的值 ? 中缀表达式和后缀表达式的特征 中缀表达式:中缀表达式与通常的表达式一样,运算符位于两个操作之间,
您可能关注的文档
- 数据机构课件第7章图2.ppt
- 数据来源计世资讯CCW.ppt
- 数据方报表系统-高效报表解决方案.pptx
- 数据流图快速入门.ppt
- 数据模型第二章数据及其描述分析.ppt
- 数据模型与概念模型.ppt
- 数据流程图的画法.ppt
- 数据流程图及数据字典.ppt
- 数据流图画法详解.ppt
- 数据源和报表布局.ppt
- 物流金融服务在供应链中的应用与风险控制策略研究报告.docx
- 城市道路桥梁景观设计可行性及成本评估报告2025.docx
- 跨境电商运动装备行业2025年物流中心智能化物流服务模式研究.docx
- 深度解析2025年智能电网分布式储能系统最佳配置方案.docx
- 2025年金融科技助力普惠金融发展路径与效果深度分析报告.docx
- 2025年文具礼品行业跨境电商保税加工企业国际化战略与布局.docx
- 2025年文具礼品行业跨境电商保税加工市场消费者满意度调查.docx
- 全球低空经济2025年航空救援与标准白皮书.docx
- 人工智能技术在2025年智能仓储物流领域的应用与挑战.docx
- 罕见病药物研发资金流向与市场回报预测研究报告.docx
最近下载
- 成本费用管理制度(最终版).pdf VIP
- 3海港总体设计规范_培训讲义-航道、锚地分析报告.pdf VIP
- 电力设备预防性试验规程QCSG114002-2011版资料.doc VIP
- Legally Blonde Scripts 律政俏佳人(中英对照).pdf VIP
- 浙江省消防技术规范难点问题操作技术指南-2025修订稿(定稿).pdf VIP
- 中华人民共和国民法典系列第七编侵权责任解读PPT课件.pptx VIP
- OWASP大语言模型人工智能应用Top10安全威胁2025.docx
- 530601-高职工商企业管理专业教学标准.pdf VIP
- 种植土覆土绿化施工方案.docx
- 2025年阿里云客服专项客服条件检测认证考试试题及答案.docx VIP
文档评论(0)