实现简单的可变长字符串栈

本文介绍了一种可自动调整大小的字符串栈实现方法,该栈可根据元素数量动态改变其容量,当栈内元素达到当前容量限制时,栈的容量会扩展为原来的两倍。此外,当栈内元素数量减少到当前容量的四分之一时,栈的容量会减半。通过这种方式,可以有效平衡内存使用效率。

Princedon 的 「Algorithms」公开课中讲到写一个存放字符串的栈,有一种实现是栈的大小随着元素的增加不断变大,采取的策略和 C++ 的 STL 一样,让栈以现在大小的 2 倍增长。

public class ResizingStackOfStrings
{
    private String[] s;
    private int N = 0;

    public ResizingStackOfStrings()
    { s = new String[1]; }

    public boolean isEmpty()
    { return N == 0; }

    public void push(String item)
    {
        if ( N == s.length) resize(2 * s.length);
        s[N++] = item;
    }

    public String pop()
    {
        String item = s[--N];
        s[N] = null;
        if (N > 0 && N == s.length/4) resize(s.length/2);
        return item; 
    }

    public void resize(int capacity)
    {
        String [] copy = new String[capacity];
        for (int i = 0; i < N; i++) 
            copy[i] = s[i];
        s = copy;
    }

    public static void main(String[] args)
    {
        ResizingStackOfStrings stack = new ResizingStackOfStrings();
        stack.push("lindaiyu");
        stack.push("hongloumeng");
        stack.push("jiabaoyu");
        System.out.println(stack.pop());
    }
}

参考

https://class.coursera.org/algs4partI-010/lecture/19

转载于:https://my.oschina.net/lvyi/blog/652306

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值