xjtu 编译原理实验 02

Cool 语言堆栈机

1. 操作说明

命令含义
int将整数数添加到栈中
+栈中压入 +
s栈中压入 s
e计算栈顶表达式的值(详见下文)
d打印栈中内容
x退出

e 命令的作用:

  1. 如果 + 在栈顶,那么 + 出栈,栈顶两整数弹出并相加,将结果压入栈
  2. 如果 s 在栈顶,那么 s 出栈,下面两个选项在栈内交换

2. 栈的实现

2.1 内部成员变量

cool 语言是一种面向对象的语言,所有函数和值都是以对象的形式存在,栈的实现也要以对象的形式进行。由于不能直接创建数组,我们的栈使用嵌套的方式进行,栈内有 3 个变量:

class Stack {

  top  : String;
  rest : Stack;
  size : Int <- 0;

};
  • top:栈顶元素
  • rest:栈中剩余元素,是当前 Stack 的子 Stack
  • size:当前栈的深度,1 为最底层(打印输出时会减 1,即从第 0 层往上爬)。同时利用该数判断栈是否为空

2.2 初始化函数

Stack 类的核心就是它的初始化函数,在该函数中我们可以看到,栈是在 rest 的嵌套中实现的。

  init(item : String, stack : Stack) : Stack {
    {
      top  <- item;
      rest <- stack;
      size <- stack.size() + 1;
      self;
    }
  };

2.3 入栈操作

入栈操作借助 init 实现:

  push(item : String) : Stack {
    (new Stack).init(item, self)
  };

因为在 Cool 语言中不能直接对 self 赋值,我们只能通过下面的方式进行入栈操作:

stack <- stack.push("<item>")
2.4 出栈操作

出栈操作只需让当前的栈变为 rest 即可:

  pop() : Stack {
    if self.size() = 0 then self
    else {
      top  <- rest.top();
      rest <- rest.remain();
      size <- size - 1;
      self;
    } fi
  };
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值