array

本文介绍了一个使用Tcl语言实现的简单栈数据结构。通过两个过程(proc):Push和Pop来实现栈的基本操作。Push过程将元素压入栈顶,而Pop过程则移除并返回栈顶元素。示例代码演示了栈的使用方法。

http://wiki.tcl.tk/1032

 

proc Push { stack value } {
        upvar $stack S
        if ![info exists S(top)] {
                set S(top) 0
        }
        set S($S(top)) $value
        incr S(top)
}
proc Pop { stack } {
        upvar $stack S
        if ![info exists S(top)] {
                return {is null}
        }
        if {$S(top) == 0} {
                return {bottom}
#               unset $S(top)
#               array unset S
#               unset $S
        } else {
                incr S(top) -1
                set x $S($S(top))
                unset S($S(top))
                return "S($S(top))=$x"
        }
}
puts [Push stack 1]
puts [Push stack 2]
puts [Push stack 3]
puts [Pop stack]
puts [Pop stack]
puts [Pop stack]
puts [Pop stack]
#puts "top =$S(top)"
puts [Pop stack]
puts "top =$S(top)"
#puts "a=$a"
#set b 1
#puts "b=$b"
#unset b
#puts "unset, b=$b"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值