码迷,mamicode.com
首页 > 其他好文 > 详细

基础的集合实现

时间:2020-06-23 13:02:21      阅读:43      评论:0      收藏:0      [点我收藏+]

标签:public   object   ack   amp   检索   item   实现类   对象   for   

引用
《算法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() {}
    }
}

基础的集合实现

标签:public   object   ack   amp   检索   item   实现类   对象   for   

原文地址:https://www.cnblogs.com/linma/p/13181425.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!