3.2栈的应用举例

由于栈具有后进先出的特性,所以致使栈成为程序设计中的有用工具。

3.2.1数制转换

十进制数N和其它d进制数的转换是计算机实现计算的基本问题,解决算法很多,其中一个简单的算法原理如下:

N = (N div d)X d + N mod d(其中div为整除运算,mod为求余运算)

例如:10进制与8进制之间的转换;

现在编一个满足下列要求的程序:对于一个任意输入的非负10进制数,打印输出与其等值的八进制数。由于上面的计算过程是从低位到高位顺序产生8进制数的各个数位,而打印输出,从高位到低位进行,恰好与计算过程相反。因此,若将计算过程产生的8进制数的各位顺序存储在栈中,则按出栈序列打印输出的即为与输入相对应的8进制数。

算法3.1:十进制转换为八进制

void conversion()
{
  //对于任意一个非负十进制整数,打印输出与其等值的八进制数;
  InitStack(S);
  scanf("%d",N);
  while(N)
  {
    Push(S,N%8);//八进制到十进制的转换计算,得到一位就直接入栈,然后再计算下一位再入栈;
    N = N/8;
  }
  while(!StackEmpty(S))
  {
    Pop(S,e);
    printf("%d",e);
  }
}

3.2.2括号匹配的检验

假设表达式中允许包含两种括号:圆括号和方括号,其嵌套的顺序随意,但是正确的格式。检验括号是否匹配的方法可用“期待的急迫程度”这个概念来描述,例如考虑下列括号序列:

[ ( [ ] [ ] ) ]

1 2 3 4 5 6 7 8

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值