Java實現棧。

來源:互聯網
上載者:User

標籤:

定義一個介面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實現棧。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.