Resizing array笨办法,每次都要新建一个临时数组
2015-08-19 11:03
387 查看
package princeton;
import java.util.NoSuchElementException;
public class MyResizingArrayQueue {
}
import java.util.NoSuchElementException;
public class MyResizingArrayQueue {
public String [] a; int count; public MyResizingArrayQueue(){ this.count = 0; this.a = new String [2]; } public void resize(int capacity){ String [] temp = new String [capacity]; for(int i =0;i<count;i++){ temp[i] =a[i]; } a = temp; } public void enqueue(String s){ if(a.length==count){ resize(2*a.length); } a[count] = s; count++; } public String dequeue(){ if (isEmpty()) throw new NoSuchElementException("Stack underflow"); String s = a[0]; String [] temp = new String[count-1]; for (int i =0;i<count-1;i++){ temp[i] = a[i+1]; } for (int i =0;i<count-1;i++){ a[i] = temp[i]; } a[count-1] = null; //a = temp; count--; if(a.length==4*count){ resize(a.length/2); } return s; } public int sizeof(){ return count; } public boolean isEmpty(){ return count ==0; } public static void main(String[] args) { // TODO Auto-generated method stub MyResizingArrayQueue mraq = new MyResizingArrayQueue(); for(int i =0;i<args.length;i++){ mraq.enqueue(args[i]); //System.out.println(mraq.a[i]); //System.out.println(mraq.a.length); } for(int i =0;i<6;i++){ System.out.println(mraq.dequeue()); System.out.println("array length is "+mraq.a.length); } }
}
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树
- [原创]java局域网聊天系统