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

服務(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大神第九部红酒气质女 | 无限在线观看免费入口 | 国产91成人精品亚洲精品 | 2048论坛永久入口 原创合集 | 精品久久免费观看 | 日本黄色高清视频网站 | 四虎com | 好湿好紧太硬了我太爽了网站 | 精品国产乱码久久久久久免费 | 小鸟酱在线看 | 99精品在线| 青青草国产免费久久久91 | 精品一区二区三区五区六区 | 暖暖 免费 高清 日本 在线1 | 精品日韩欧美一区二区三区 | 女医学护士一级毛片 | 日产乱码卡一卡2卡三卡四福利 | 精品小视频在线 | 午夜福利电影网站鲁片大全 | 91传媒制片厂制作传媒破解版 | 欧美日韩亚洲第一区在线 | 校花被吃奶还摸下面 | 操小女人| 非洲黑人gay巨大 | 久草在线精彩免费视频 | 激情五月姐姐 | 日韩亚洲人成在线综合 | 亚洲国产精品牛在线 | 国产日韩精品一区二区三区 | 九9热这里只有真品 | 青青青在线观看国产精品 | 边吃胸边膜下刺激免费男对女 | 京东热dj6666| 免费精品视频在线 | 高清国产精品久久久久 | 国产一区日韩二区欧美三 | 超鹏97国语| a∨在线观看 | 小SAO货叫大声点妓女 |