一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - Java中使用數(shù)組實現(xiàn)棧數(shù)據(jù)結(jié)構(gòu)實例

Java中使用數(shù)組實現(xiàn)棧數(shù)據(jù)結(jié)構(gòu)實例

2019-12-08 21:06junjie JAVA教程

這篇文章主要介紹了Java中使用數(shù)組實現(xiàn)棧數(shù)據(jù)結(jié)構(gòu)實例,本文先是講解了實現(xiàn)棧至少應(yīng)該包括以下幾個方法等知識,然后給出代碼實例,需要的朋友可以參考下

Java語言中最重要的數(shù)據(jù)結(jié)構(gòu)之一,它的實現(xiàn),至少應(yīng)該包括以下幾個方法:

1.pop() 出棧操作,彈出棧頂元素。
2.push(E e) 入棧操作
3.peek() 查看棧頂元素
4.isEmpty() 棧是否為空

另外,實現(xiàn)一個棧,還應(yīng)該考慮到幾個問題:

1.棧的初始大小以及棧滿以后如何新增棧空間
2.對棧進(jìn)行更新時需要進(jìn)行同步

簡單示例,使用數(shù)組實現(xiàn)棧,代碼如下:

復(fù)制代碼代碼如下:


public class Stack<E> { 

 

    // Java 不支持泛型數(shù)組,如需使用,請使用Java提供的容器  
    private Object[] stack; 

    // 棧的默認(rèn)初始大小  
    private static final int INIT_SIZE = 2; 

    // 棧頂索引  
    private int index; 

    public Stack() {  
        stack = new Object[INIT_SIZE];  
        index = -1;  
    } 

    /**  
     * 構(gòu)造方法  
     *   
     * @param initSize  
     *            棧的初始大小  
     */ 
    public Stack(int initSize) {  
        if (initSize < 0) {  
            throw new IllegalArgumentException();  
        }  
        stack = new Object[initSize];  
        index = -1;  
    } 

    /**  
     * 出棧操作  
     *   
     * @return 棧頂對象  
     */ 
    public synchronized E pop() {  
        if (!isEmpty()) {  
            E temp = peek();  
            stack[index--] = null;  
            return temp;  
        }  
        return null;  
    } 

    /**  
     * 入棧操作  
     *   
     * @param obj  
     *            等待入棧的對象  
     */ 
    public synchronized void push(E obj) {  
        if (isFull()) {  
            Object[] temp = stack;  
            // 如果棧滿,則創(chuàng)建空間為當(dāng)前棧空間兩倍的棧  
            stack = new Object[2 * stack.length];  
            System.arraycopy(temp, 0, stack, 0, temp.length);  
        }  
        stack[++index] = obj;  
    } 

    /**  
     * 查看棧頂對象  
     *   
     * @return 棧頂對象  
     */ 
    public E peek() {  
        if (!isEmpty()) {  
            return (E) stack[index];  
        }  
        return null;  
    } 

    /**  
     * 查看棧是否為空  
     *   
     * @return 如果棧為空返回true,否則返回false  
     */ 
    public boolean isEmpty() {  
        return index == -1;  
    } 

    /**  
     * 查看棧是否滿  
     *   
     * @return 如果棧滿返回true,否則返回false  
     */ 
    public boolean isFull() {  
        return index >= stack.length - 1;  
    }  
}

 

最后說明,Java中實現(xiàn)了棧(java.util.Stack)的數(shù)據(jù)結(jié)構(gòu),它是通過繼承Vector類實現(xiàn)的,一般情況下我們直接拿來用就行了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 好姑娘在线观看完整版免费 | 欧美精品超清在线播放 | 国产91区 | 大又大又黄又爽免费毛片 | 99视频都是精品热在线播放 | 免费370理论片中文字幕 | 欧美贵妇vs高跟办公室 | 国产日产欧产精品精品软件 | 性做久久久久免费观看 | 万域之王动漫在线观看全集免费播放 | 人生路不在线观看完整版 | xnxx18美女| 果冻传媒九一制片厂网站 | 国产精品久久国产精品99盘 | 日本最新伦中文字幕 | 精品一区二区三区在线视频观看 | 好大~好爽~再进去一点 | 欧美成人三级伦在线观看 | 维修工的调教 | 精品视频一区二区 | 强波多野结衣女教师 | 国产精品久久久久久久人人看 | 国产aaa伦理片 | 国产成人精品一区二区不卡 | 亚洲国产精品一在线观看 | 激情五月姐姐 | 国产欧美视频一区二区三区 | 动漫美女被羞羞产奶 | 亚洲精品资源在线 | 国产成人精品第一区二区 | 顶级欧美做受xxx000 | 青青草原在线 | 97精品国产高清在线看入口 | 俄罗斯性高清完整版 | 午夜无码片在线观看影院 | 亚洲一区二区三区91 | 午夜免费啪视频观看视频 | 欧美一区二区三区不卡视频 | 免费被靠视频动漫 | 久久成人a毛片免费观看网站 | 亚洲色图第四页 |