2.2 栈的应用举例

例一:数制转换 算法基于原理: N = (N div d) * d + N mod d 十进制转化为八进制数:除八取余; 十进制转化为二进制数:除二取余; B :二进制数。 Q :八进制数。 D :十进制数。 H :十六进制数。 例如:(1348)D = (2504)Q 运算过程:(商为0时结束)  N       N div 8       N mod 8  1348      168   ...
摘要由CSDN通过智能技术生成
例一:数制转换


算法基于原理:
N = (N div d) * d + N mod d
十进制转化为八进制数:除八取余;
十进制转化为二进制数:除二取余;

B :二进制数。 Q :八进制数。 D :十进制数。 H :十六进制数。
例如:(1348)D = (2504)Q
运算过程:(商为0时结束)
 N       N div 8       N mod 8
 1348      168          4
 168        21            0
 21          2             5
 2            0             2

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);
}
}//conversion

例二:括号匹配的检验

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值