棧的鏈式存儲結(jié)構(gòu)

//鏈表
typedef struct NODE
{
    int data;//數(shù)據(jù)域
    struct NODE * next;//指針域
}* Node;
//棧
typedef struct STACK
{
    Node top;//棧頂
    Node bottom;//棧底
    
} * Stack;
//初始化
Stack init_stack();
//入棧
void push_stack(Stack stack,int data);
//出棧
void pop_stack(Stack stack,int * pData);
//遍歷
void traverse_stack(Stack stack);
//清空
void clear_stack(Stack stack);

int main(int argc, const char * argv[]) {
    
    Stack stack = init_stack();
    
    push_stack(stack, 1);
    push_stack(stack, 2);
    push_stack(stack, 3);
    push_stack(stack, 4);
    
//    traverse_stack(stack);
//    pop_stack(stack, NULL);
//    traverse_stack(stack);
    
    clear_stack(stack);
    
    return 0;
}

//初始化
Stack init_stack()
{
    Stack stack = (Stack)malloc(sizeof(Stack));
    stack->top = (Node)malloc(sizeof(Node));
    if (stack->top == NULL) {
        printf("分配內(nèi)存失敗");
        exit(-1);
    }else
    {
        stack->bottom = stack->top;
        stack->top->next = NULL;
    }
    
    return  stack;
}
//入棧
void push_stack(Stack stack,int data)
{
    Node new = (Node)malloc(sizeof(Node));
    new->data = data;
    //每次新建節(jié)點指向棧頂
    new->next = stack->top;
    //棧頂指向新節(jié)點
    stack->top = new;
}
//出棧
void pop_stack(Stack stack,int * pData)
{
    if (stack->top == stack->bottom) {
        printf("已經(jīng)是空棧,不能出棧");
        exit(-1);
    }
    pData = &stack->top->data;
    Node p = stack->top;
    stack->top = p->next;
    free(p);
    p = NULL;
}
//遍歷
void traverse_stack(Stack stack)
{
    Node p = stack->top;
    
    while (p != stack->bottom) {
        printf("%d   ",p->data);
        p = p->next;
    }
    printf("\n");
}
//清空
void clear_stack(Stack stack)
{
    if (stack->top == stack->bottom) {
        return;
    }else
    {
        Node p = stack->top;
        Node q;
        
        while (p != stack->bottom) {
            q = p->next;
            free(p);
            p = q;
        }
        stack->top = stack->bottom;
    }
}

demo地址

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市狈蚤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌割按,老刑警劉巖两波,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件要拂,死亡現(xiàn)場離奇詭異巴比,居然都是意外死亡术奖,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門轻绞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來采记,“玉大人,你說我怎么就攤上這事政勃∵罅洌” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵奸远,是天一觀的道長既棺。 經(jīng)常有香客問我讽挟,道長,這世上最難降的妖魔是什么丸冕? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任戏挡,我火速辦了婚禮,結(jié)果婚禮上晨仑,老公的妹妹穿的比我還像新娘。我一直安慰自己拆檬,他們只是感情好洪己,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著竟贯,像睡著了一般答捕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屑那,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天拱镐,我揣著相機與錄音,去河邊找鬼持际。 笑死沃琅,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蜘欲。 我是一名探鬼主播益眉,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼姥份!你這毒婦竟也來了郭脂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤澈歉,失蹤者是張志新(化名)和其女友劉穎展鸡,沒想到半個月后埃难,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體莹弊,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年涡尘,在試婚紗的時候發(fā)現(xiàn)自己被綠了箱硕。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡悟衩,死狀恐怖剧罩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情座泳,我是刑警寧澤惠昔,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布幕与,位于F島的核電站,受9級特大地震影響镇防,放射性物質(zhì)發(fā)生泄漏啦鸣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一来氧、第九天 我趴在偏房一處隱蔽的房頂上張望诫给。 院中可真熱鬧,春花似錦啦扬、人聲如沸中狂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胃榕。三九已至,卻和暖如春瞄摊,著一層夾襖步出監(jiān)牢的瞬間勋又,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工换帜, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留楔壤,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓惯驼,卻偏偏與公主長得像挺邀,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子跳座,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

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