java數(shù)據(jù)結(jié)構(gòu)之java實(shí)現(xiàn)棧
import java.util.Arrays;
/**
* 棧的實(shí)現(xiàn)<br>
* @author Skip
* @version 1.0
*/
public class Stack<T> {
private int size; //棧中元素的個(gè)數(shù)
private Object[] arr; //底層數(shù)組
private final int defaultLength = 200; //默認(rèn)長度
/**
* 無參構(gòu)造,使用默認(rèn)長度初始化數(shù)組
*/
public Stack(){
arr = new Object[defaultLength];
size = 0;
}
/**
* 使用長度參數(shù)初始化數(shù)組
* @param length 長度
*/
public Stack(int length){
arr = new Object[length];
size = 0;
}
/**
* 入棧
* @param element 數(shù)據(jù)
*/
public void push(T element){
//是否需要擴(kuò)容
if(size >= arr.length){
//數(shù)組擴(kuò)容
extendCapacity(size+1);
}
arr[size++] = element;
}
/**
* 出棧
* @return 數(shù)據(jù)
*/
@SuppressWarnings("unchecked")
public T pop(){
//元素個(gè)數(shù)為0,無法執(zhí)行出棧操作
if(size==0){
return null;
}
T t = (T)arr[size-1];
arr[--size] = null; //數(shù)據(jù)已出棧,還原為null
return t;
}
/**
* 清空棧
*/
public void clear(){
for(int i=0;i<size;i++){
arr[i]=null;
}
size = 0;
}
/**
* 獲得當(dāng)前棧中元素的個(gè)數(shù)
* @return 元素的個(gè)數(shù)
*/
public int getSize(){
return size;
}
/**
* 判斷是否為空棧
* @return 空為true,非空為false
*/
public boolean isEmpty(){
return size == 0;
}
/**
* 打印棧中所有的元素
*/
@SuppressWarnings("unchecked")
public void printStack(){
for(int i=0;i<size;i++){
System.out.print(((T)arr[i]).toString());
}
System.out.println();
}
/**
* 擴(kuò)容
* @param length 需要的長度
*/
private void extendCapacity(int length){
//當(dāng)前數(shù)組長度和需要的長度取最大
int minCapacity = Math.max(arr.length, length);
//判斷是否需要擴(kuò)容
if(minCapacity - arr.length>0){
//數(shù)組長度增加一半
int newLength = arr.length + arr.length/2;
//如果新的長度還比需求要小,將需求的長度作為數(shù)組長度
if(newLength < minCapacity){
newLength=minCapacity;
}
//數(shù)組長度不能超過Integer.Max_Value
if(newLength > Integer.MAX_VALUE - 8){
newLength = Integer.MAX_VALUE;
}
//數(shù)組擴(kuò)容
arr = Arrays.copyOf(arr, newLength);
}
}
}
- java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列
- java 數(shù)據(jù)結(jié)構(gòu)中棧結(jié)構(gòu)應(yīng)用的兩個(gè)實(shí)例
- Java模擬棧和隊(duì)列數(shù)據(jù)結(jié)構(gòu)的基本示例講解
- 用Java代碼實(shí)現(xiàn)棧數(shù)據(jù)結(jié)構(gòu)的基本方法歸納
- Java中使用數(shù)組實(shí)現(xiàn)棧數(shù)據(jù)結(jié)構(gòu)實(shí)例
- Java語言實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)棧代碼詳解
相關(guān)文章
淺談spring中用到的設(shè)計(jì)模式及應(yīng)用場(chǎng)景
下面小編就為大家?guī)硪黄獪\談spring中用到的設(shè)計(jì)模式及應(yīng)用場(chǎng)景。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08Java中對(duì)AtomicInteger和int值在多線程下遞增操作的測(cè)試
這篇文章主要介紹了Java中對(duì)AtomicInteger和int值在多線程下遞增操作的測(cè)試,本文得出AtomicInteger操作 與 int操作的效率大致相差在50-80倍上下的結(jié)論,需要的朋友可以參考下2014-09-09spring Retryable注解實(shí)現(xiàn)重試詳解
這篇文章主要介紹了spring Retryable注解實(shí)現(xiàn)重試詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09Java調(diào)用JavaScript實(shí)現(xiàn)字符串計(jì)算器代碼示例
這篇文章主要介紹了Java調(diào)用JavaScript實(shí)現(xiàn)字符串計(jì)算器代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-12-12Java建造者模式構(gòu)建復(fù)雜對(duì)象的最佳實(shí)踐
建造者模式,是一種對(duì)象構(gòu)建模式?它可以將復(fù)雜對(duì)象的建造過程抽象出來,使這個(gè)抽象過程的不同實(shí)現(xiàn)方法可以構(gòu)造出不同表現(xiàn)的對(duì)象。本文將通過示例講解建造者模式,需要的可以參考一下2023-04-04劍指Offer之Java算法習(xí)題精講鏈表與數(shù)組專項(xiàng)訓(xùn)練
跟著思路走,之后從簡單題入手,反復(fù)去看,做過之后可能會(huì)忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會(huì)發(fā)現(xiàn)質(zhì)的變化2022-03-03