下壓棧實(shí)現(xiàn)(可動態(tài)調(diào)整棧內(nèi)存大小)

創(chuàng)建ResizeArrayStack實(shí)現(xiàn)Iterable接口使得ResizeArrayStack能夠被迭代崭倘,用Item代替所有的數(shù)據(jù)類型祥楣。
public class ResizeArrayStack<Item> implements Iterable<Item>

//創(chuàng)建存放數(shù)據(jù)的數(shù)組(棧)
private Item[] stack = ((Item[])new Object[1]);
//記錄棧中的元素個數(shù),指明棧頂元素的位置(count-1)
private int count = 0;
//判斷棧是否為空
public boolean isEmpty(){
    return count == 0;
}
//返回迭代器,可用于迭代棧元素
@Override
public Iterator<Item> iterator() {
    return new ResizeArrayStackIterator();
}

/**
 * 重置數(shù)組的大小
 */
private void resize(int max){ 
    Item[] newStack = (Item[]) new Object[max];
    for(int i = 0; i < stack.length; i ++){
        newStack[i] = stack[i];
    }
    stack = newStack;
}
//入棧操作
public void push(Item item){
    if(count == stack.length){
        resize(stack.length * 2);
    }
    stack[count++] = item;
}
/**
 * 出棧操作
 * @return
 */
public Item pop(){
    Item topItem = stack[--count];
    stack[count] = null;
    if(count >0 && count == stack.length/4)
        resize(stack.length/2);
    return topItem;
}
//創(chuàng)建迭代器
class ResizeArrayStackIterator implements Iterator<Item>{
    int i = count;
    @Override
    public boolean hasNext() {
        return i > 0;
    }
    @Override
    public Item next() {
        return stack[--i];
    }
    @Override
    public void remove() {
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末培廓,一起剝皮案震驚了整個濱河市惹悄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌肩钠,老刑警劉巖泣港,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異价匠,居然都是意外死亡当纱,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進(jìn)店門踩窖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惫东,“玉大人,你說我怎么就攤上這事毙石。” “怎么了颓遏?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵徐矩,是天一觀的道長。 經(jīng)常有香客問我叁幢,道長滤灯,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任曼玩,我火速辦了婚禮鳞骤,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘黍判。我一直安慰自己豫尽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布顷帖。 她就那樣靜靜地躺著美旧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪贬墩。 梳的紋絲不亂的頭發(fā)上榴嗅,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天,我揣著相機(jī)與錄音陶舞,去河邊找鬼嗽测。 笑死,一個胖子當(dāng)著我的面吹牛肿孵,可吹牛的內(nèi)容都是我干的唠粥。 我是一名探鬼主播疏魏,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼厅贪!你這毒婦竟也來了蠢护?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤养涮,失蹤者是張志新(化名)和其女友劉穎葵硕,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贯吓,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡懈凹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了悄谐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片介评。...
    茶點(diǎn)故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖爬舰,靈堂內(nèi)的尸體忽然破棺而出们陆,到底是詐尸還是另有隱情,我是刑警寧澤情屹,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布坪仇,位于F島的核電站,受9級特大地震影響垃你,放射性物質(zhì)發(fā)生泄漏椅文。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一惜颇、第九天 我趴在偏房一處隱蔽的房頂上張望皆刺。 院中可真熱鬧,春花似錦凌摄、人聲如沸羡蛾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽林说。三九已至,卻和暖如春屯伞,著一層夾襖步出監(jiān)牢的瞬間腿箩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工劣摇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留珠移,地道東北人。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像钧惧,于是被迫代替她去往敵國和親暇韧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評論 2 348

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理浓瞪,服務(wù)發(fā)現(xiàn)懈玻,斷路器,智...
    卡卡羅2017閱讀 134,633評論 18 139
  • 對象的創(chuàng)建與銷毀 Item 1: 使用static工廠方法乾颁,而不是構(gòu)造函數(shù)創(chuàng)建對象:僅僅是創(chuàng)建對象的方法涂乌,并非Fa...
    孫小磊閱讀 1,967評論 0 3
  • 一湾盒、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,257評論 0 16
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法诅妹,內(nèi)部類的語法罚勾,繼承相關(guān)的語法,異常的語法吭狡,線程的語...
    子非魚_t_閱讀 31,598評論 18 399
  • 分手是早已注定的結(jié)局划煮, “朋友圈”幽怨地問我:“你到底有沒有真心地愛過我分衫?”我背對著“朋友圈”望著殘陽如血的遠(yuǎn)方深...
    流年飛螢閱讀 353評論 0 1