栈(Stack)的应用2例--符号平衡和撤销的实现

本文通过实例介绍了栈在符号平衡检查和撤销功能中的应用。在符号平衡部分,详细阐述了如何利用栈的后进先出(LIFO)特性检查括号的匹配性;在撤销部分,说明了如何利用栈实现编辑器的撤销功能,即通过栈来记录用户的操作历史。
摘要由CSDN通过智能技术生成

1. 前言

数据结构学起来很枯燥,很多教科书只给了定义、实现,同学们并不知道这东西有什么用。对于绝大多数同学来说,所学的计算机类专业应该更靠近工程方向,因此学以致用就很重要啦。

2. 关于LIFO和FILO

栈的特点是后进先出、先进后出。那么,在这里举两个应用的例子:符号平衡和撤销。

3. 符号平衡

3.1 符号平衡的思路

给出一个表达式:(7 + 3) * 8,不难发现,这里的括号必须是左右平衡的,如果写成(7 + 3 * 8,那就出问题啦,究竟应该先计算什么呢?另外,我们在写C/C++/JAVA代码的时候肯定会用到{},比如定义一个类:

public class Mdzzer{
   
    private grade;
    private class;

    public 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值