Java數(shù)據(jù)結(jié)構(gòu)之棧

棧只允許訪問一個數(shù)據(jù)項(xiàng):即最后插入的數(shù)據(jù)項(xiàng)饿自。移除這個數(shù)據(jù)項(xiàng)后才能訪問倒數(shù)第二個插入的數(shù)據(jù)項(xiàng)汰翠,依次類推。所以棧是一個先進(jìn)后出的數(shù)據(jù)結(jié)構(gòu)

棧的代碼實(shí)現(xiàn):

public class stack {
    private long[] stackArray;
    private int maxSize;
    private int top;

    public stack(int s){
        maxSize=s;
        stackArray=new long[maxSize];
        top=-1;

    }
    //入棧
    public void push(long value){
        stackArray[++top]=value;
    }
    //出棧
    public long pop(){
        return stackArray[top--];
    }
    //查看棧頂元素
    public long peek(){
        return stackArray[top];
    }
    public boolean isEmpty(){
        return (top==-1);
    }
    public boolean isFull(){
        return (top==maxSize-1);
    }

    public static void main(String[] args) {
        stack s=new stack(10);
        s.push(22);
        s.push(1);
        s.push(88);
        s.push(66);

        while (!s.isEmpty()){
            long val=s.pop();
            System.out.println(val);
        }
    }
}

出錯處理

有不同的方法來處理?xiàng)5腻e誤昭雌。當(dāng)向已經(jīng)滿了的棧用再添加一個數(shù)據(jù)項(xiàng)复唤,或要從空棧中彈出一個數(shù)據(jù)項(xiàng)時會發(fā)生錯誤,可以把處理這些錯誤的工作推給類用戶烛卧,用戶在插入數(shù)據(jù)項(xiàng)前要確定棧不滿:

if(!stack.isFull()){
    insert(item);
}

棧實(shí)例1:單詞逆序

上面提供了long的棧佛纫,讀者可以自行改造成char類型的棧

class Reverser{
    private String input;
    private String output;

    public Reverser(String in){
        input=in;
    }

    public String doRev(){
        int stackSize=input.length();
        stack s=new stack(stackSize);

        for(int j=0;j<input.length();j++){
            char ch=input.charAt(j);
            s.push(ch);
        }
        output=" ";
        while(!s.isEmpty()){
            char ch=s.pop();
            output=output+ch;
        }
        return output;
    }

    public static void main(String[] args) throws IOException {
        String input,output;

        while(true){
            System.out.println("請輸入字符串");
            System.out.flush();
            input=getString();
            if(input.equals("")){
                break;
            }
            Reverser reverser=new Reverser(input);
            output= reverser.doRev();
            System.out.println(output);
        }
    }

    public static String getString() throws IOException {
        InputStreamReader isr=new InputStreamReader(System.in);
        BufferedReader br=new BufferedReader(isr);
        String s=br.readLine();
        return s;
    }
}

棧是一個概念上的輔助工具,棧通過提供限定性訪問方法push和pop唱星,使程序易讀而且不容易出錯

棧的效率

數(shù)據(jù)項(xiàng)入棧和出棧的時間復(fù)雜度都為常數(shù)O(1)雳旅,這也就是說,棧操作所耗時間不依賴與棧中數(shù)據(jù)項(xiàng)的個數(shù)间聊,因此操作時間很短,棧不需要比較和移動操作抵拘。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末哎榴,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尚蝌,老刑警劉巖迎变,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異飘言,居然都是意外死亡衣形,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門姿鸿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谆吴,“玉大人,你說我怎么就攤上這事苛预【淅牵” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵热某,是天一觀的道長腻菇。 經(jīng)常有香客問我,道長昔馋,這世上最難降的妖魔是什么筹吐? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮秘遏,結(jié)果婚禮上丘薛,老公的妹妹穿的比我還像新娘。我一直安慰自己垄提,他們只是感情好榔袋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著铡俐,像睡著了一般凰兑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上审丘,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天吏够,我揣著相機(jī)與錄音,去河邊找鬼滩报。 笑死锅知,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的脓钾。 我是一名探鬼主播售睹,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼可训!你這毒婦竟也來了昌妹?” 一聲冷哼從身側(cè)響起捶枢,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎飞崖,沒想到半個月后烂叔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡固歪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年蒜鸡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牢裳。...
    茶點(diǎn)故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡逢防,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贰健,到底是詐尸還是另有隱情胞四,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布伶椿,位于F島的核電站辜伟,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏脊另。R本人自食惡果不足惜导狡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望偎痛。 院中可真熱鬧旱捧,春花似錦、人聲如沸踩麦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谓谦。三九已至贫橙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間反粥,已是汗流浹背卢肃。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留才顿,地道東北人莫湘。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像郑气,于是被迫代替她去往敵國和親幅垮。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容