码迷,mamicode.com
首页 > 编程语言 > 详细

Java实现栈。

时间:2015-05-27 11:44:39      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:

定义一个接口MyStack接口:

package Stack;

public interface MyStack<T> {
boolean isEmpty();
int length();
boolean push(T date);
T pop();
}

数组实现:

package Stack;

public class ArrayStack<T> implements MyStack<T>{
private Object[] objs = new Object[16];
// size相当于游标
private int size = 0;
public boolean isEmpty() {

return size==0;
}

@Override
public int length() {
// TODO Auto-generated method stub
return size;
}

@Override
public boolean push(T date) {
if(size>=objs.length){
resize();
}
objs[size]=date;
size++;
return true;
}

@Override
public T pop() {
if(size==0){
return null;
}

return (T) objs[--size];
}
public void resize(){
Object[] temp = new Object[objs.length*3/2+1];
for(int i=0;i<size;i++){
temp[i]=objs[i];
objs[i] = null;
}
objs=temp;
}
public String toString(){
StringBuffer sb= new StringBuffer();
sb.append("ArrayStack:[");
for(int i =0;i<size;i++){
sb.append(objs[i]);
if(i!=size-1){
sb.append(",");
}
}
sb.append("]");
return sb.toString();
}
}

链表实现:

package Stack;

public class LinkStack<T> implements MyStack<T> {
Node top=null;
int size=0;

@Override
public boolean isEmpty() {
// TODO Auto-generated method stub
return top==null;
}

@Override
public int length() {

return size;
}

@Override
public boolean push(T date) {
Node node = new Node();
node.date = date;
node.node = top;
top=node;
size++;
return true;
}

@Override
public T pop() {
if(size!=0){
Node node = top;
top=node.node;
size--;
return node.date;
}
return null;
}
class Node{
private Node node;
private T date;
}
}

测试:

/**
*
*/
package Stack;

import org.junit.Test;


/**
* @author zjj19960106
*
*/
public class TestSpeed {
class Person{
public Person(String name, int age) {
this.name=name;
this.age=age;
}
private String name;
private int age;
}
@Test
public void testSpeed() {
MyStack<Person> stack = new ArrayStack<Person>();
int num = 10000000;
long start = System.currentTimeMillis();
for (int i = 0; i < num; i++) {
stack.push(new Person("xing", 25));
}
long temp = System.currentTimeMillis();
System.out.println("push time: " + (temp - start));
while (stack.pop() != null) ;
System.out.println("pop time: " + (System.currentTimeMillis() - temp));
}

}

结果:链表的时间大于数组,栈的操作是对栈顶进行,所以使用数组也是O(1),不会出现数组中的元素移动位置,而使用栈每个数据还有进行封装成节点,所以时间比数组长。

Java实现栈。

标签:

原文地址:http://www.cnblogs.com/52zjj/p/4532604.html

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