基础的集合实现

引用
《算法4》1.3.2.5 迭代

特点:小巧精妙

  • 自动扩缩容
  • 避免对象游离
  • 使用数组能够高效检索数据
  • 实现Iterable 对外提供 Iterator
  • Bag、Queue、Stack、List基本都可以依葫芦画瓢
  • 这是一个线程不安全的实现类
import java.util.Iterator;

public class ResizingArrayStack<Item> implements Iterable<Item> {
    private Item[] a = new (Item[]) new Object[1]; 	// 栈元素
    private int N = 0;								// 元素数量
    public boolean isEmpty() {return N == 0;}
    public int size() {return N;}
    
    private void resize(int max) {
        // 将栈移动到一个大小为max的新数组
        Item[] temp = (Item[]) new Object[max];
        for (int i=0; i<N; i++)
            temp[i] = a[i];
        a = temp;
    }
    
    public void push(Item item) {
        // 将元素添加到栈顶
        if (N == a.length) resize(2*a.length);
        a[N++] = item;
    }
    
    public Item pop() {
        // 从栈顶删除元素
        Item item = a[--N];
        //避免对象游离
        a[N] == null;	
        if (N > 0 && N == a.length/4) resize(a.length/2);
        return item;
    }
    
    public Iterator<Item> iterator() {return new ReverseArrayIterator();}
    
    public class ReverseArrayIterator implements Iterator<Item> {
        // 支持后进先出的迭代
        private int i = N;
        public boolean hashNext() {return i>0;};
        public Item next() {return a[--i];}
        public void remove() {}
    }
}
posted @ 2020-06-23 12:11  小马快跑3  阅读(104)  评论(0编辑  收藏  举报