美文网首页
手写Java数组栈

手写Java数组栈

作者: jack_520 | 来源:发表于2018-03-29 18:21 被阅读0次

package test;

import java.util.Iterator;

public class Bag<item> implements Iterable<item>{

private int N =0;

@SuppressWarnings("unchecked")

private Item[] enty = (Item[]) new Object[1];

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

public Item pop(){

Item item = enty[--N];

enty[N] = null;

if(N>0 && N == enty.length/4){resize(enty.length/2);}

return item;

}

public void push(Item item){

if(item != null && N == enty.length){resize(2*enty.length);}

enty[N++]= item;

}

private void resize(int i) {

Item[] a = (Item[]) new Object[i];

for(int j=0;j

Item[] item = enty;

enty =(Item[]) new Object[i];

for(int j=0;jbag = new Bag();

Iteratorit = bag.iterator();

//if(bag.hasNext()){

//bag.next();

//}if(it.hasNext()){it.next();

}

}

private class removeArrayIterator implements Iterator{

private int i = N;

@Override

public boolean hasNext() {return i>0;}

@Overridepublic Item next() {return enty[--i];}

@Overridepublic void remove() {

if(N>0){Item item = enty[--N];enty[N] = null; } if(N>0&& N == enty.length/4){ resize(enty.length/2); }}}

//@Override

//public void remove() {

//if(N>0){

//Item item = enty[--N];//enty[N] = null;

//}

//if(N>0&& N == enty.length/4){

//resize(enty.length/2);

//}

//}

@Overridepublic Iterator iterator() {

return new removeArrayIterator();

}

// @Override

// public boolean hasNext() {

// // TODO Auto-generated method stub

// return false;

// }

// @Override

// public Item next() {

// // TODO Auto-generated method stub

// return null;

// }

// @Override

// public void remove() {

// // TODO Auto-generated method stub

//

// }

}

下面是Iterator类与与Iterable类区别。转载自  https://www.cnblogs.com/ttylcc/p/5475890.html

https://www.cnblogs.com/ttylcc/p/5475890.html

刚刚接触Java的集合类,从Collection一步一步向上查看源码,发现Iterable和Iterator这两个接口,刚开始看有点糊涂,怎么一下从Iterable接口继承,一下Iterator()方法又在Iterable里面?下面一张图可以比较清楚显示两者关系,用的是mindnode作图。

我在刚开始看的时候,第一个疑问就是:为什么Collection接口要继承于Iterable接口,而不是Iterator接口?在stackoverflow上找了很多回答,总结了三点,希望对刚刚接触Collection集合类也在这里有困惑的同学有所帮助。原因大致有三点:

1. 在jdk 1.5以后,引入了Iterable,使用foreach语句(增强型for循环)必须使用Iterable类。

2. Java设计者让Collection继承于Iterable而不是Iterator接口。首先要明确的是,Iterable的子类Collection,Collection的子类List,Set等,这些是数据结构或者说放数据的地方。Iterator是定义了迭代逻辑的对象,让迭代逻辑和数据结构分离开来,这样的好处是可以在一种数据结构上实现多种迭代逻辑。

3. 更重要的一点是:每一次调用Iterable的Iterator()方法,都会返回一个从头开始的Iterator对象,各个Iterator对象之间不会相互干扰,这样保证了可以同时对一个数据结构进行多个遍历。这是因为每个循环都是用了独立的迭代器Iterator对象。

相关文章

  • 手写Java数组栈

    package test; import java.util.Iterator; public class Bag...

  • 基于动态数组的实现 Java实现 基于链表的栈的实现 Java实现

  • 数组实现栈

    之前面试的时候,有过面试官让手写数组实现栈,特记录如下:

  • java - 手写队列/栈

    话不多少,直接上代码 1. 手写队列 输出 2. 手写栈 输出

  • Java集合类

    Java集合框架 概述 Java集合工具包位于Java.util包下,包含许多常用数据结构,如数组、链表、栈、队列...

  • Java集合·01·总体框架

    一、概述 Java集合是java提供的工具包,包含了常用的数据结构:集合、链表、队列、栈、数组、映射等。Java集...

  • Java集合框架

    Java集合框架 概述 Java集合工具包位于Java.util包下,包含了很多常用的数据结构,如数组、链表、栈、...

  • Java集合干货系列-集合总体大纲

    前言 Java集合是java提供的工具包,包含了常用的数据结构:集合、链表、队列、栈、数组、映射等。Java集合工...

  • Vector

    Java集合 Java集合是java提供的工具包,包含了常用的数据结构:集合、链表、队列、栈、数组、映射等。Jav...

  • Collection 总结

    Collection Java集合是java提供的工具包,包含了常用的数据结构:集合、链表、队列、栈、数组、映射等...

网友评论

      本文标题:手写Java数组栈

      本文链接:https://www.haomeiwen.com/subject/wpkvcftx.html