亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言數據結構之棧簡單操作

2020-01-26 14:02:59
字體:
來源:轉載
供稿:網友

C語言數據結構之棧簡單操作

實驗:

編寫一個程序實現順序棧的各種基本運算,并在此基礎上設計一個主程序,完成如下功能:

(1)初始化順序棧
(2)插入元素
(3)刪除棧頂元素
(4)取棧頂元素
(5)遍歷順序棧
(6)置空順序棧

分析:

棧的順序存儲結構簡稱為順序棧,它是運算受限的順序表。

對于順序棧,入棧時,首先判斷棧是否為滿,棧滿的條件為:p->top= =MAXNUM-1,棧滿時,不能入棧; 否則出現空間溢出,引起錯誤,這種現象稱為上溢。

出棧和讀棧頂元素操作,先判棧是否為空,為空時不能操作,否則產生錯誤。通常??兆鳛橐环N控制轉移的條件。

注意:

(1)順序棧中元素用向量存放
(2)棧底位置是固定不變的,可設置在向量兩端的任意一個端點
(3)棧頂位置是隨著進棧和退棧操作而變化的,用一個整型量top(通常稱top為棧頂指針)來指示當前棧頂位置

順序棧的實現:

#include <stdio.h> #include <malloc.h>  typedef int SElemType; typedef int Status; #define INIT_SIZE 100 #define STACKINCREMENT 10 #define Ok 1 #define Error 0 #define True 1 #define False 0 typedef struct {   SElemType *base;   SElemType *top;   int stacksize; }SqStack;  //初始化棧 Status InitStack(SqStack *s) {   s->base = (SElemType *)malloc(INIT_SIZE * sizeof(SElemType));   if(!s->base)   {     puts("存儲空間分配失?。?);     return Error;   }   s->top = s->base;   s->stacksize = INIT_SIZE;   return Ok; }  //清空棧 Status ClearStack(SqStack *s)  {   s->top = s->base;   return Ok;  }  //棧是否為空 Status StackEmpty(SqStack *s)  {   if(s->top == s->base)    return True;   else    return False;  }  //銷毀棧 Status Destroy(SqStack *s) {   free(s->base);   s->base = NULL;   s->top = NULL;   s->stacksize=0;   return Ok; }  //獲得棧頂元素 Status GetTop(SqStack *s, SElemType &e) {   if(s->top == s->base) return Error;   e = *(s->top - 1);   return Ok; }  //壓棧 Status Push(SqStack *s, SElemType e) {   if(s->top - s->base >= s->stacksize)//棧滿   {     s->base = (SElemType *)realloc(s->base, (s->stacksize + STACKINCREMENT) * sizeof(SElemType));     if(!s->base)     {       puts("存儲空間分配失??!");       return Error;     }     s->top = s->base + s->stacksize;//修改棧頂位置     s->stacksize += STACKINCREMENT;//修改棧長度    }   *s->top++ = e;   return Ok; }  //彈棧 Status Pop(SqStack *s, SElemType *e) {   if(s->top == s->base) return Error;   --s->top;   *e = *(s->top);   return Ok; }  //遍歷棧 Status StackTraverse(SqStack *s,Status(*visit)(SElemType))  {    SElemType *b = s->base;//此處不能直接用base或top移動,即不能改變原棧的結構    SElemType *t = s->top;   while(t > b)    visit(*b++);   printf("/n");   return Ok;  }  Status visit(SElemType c)  {   printf("%d ",c);   return Ok;  } 

測試代碼:

int main() {   SqStack a;   SqStack *s = &a;   SElemType e;   InitStack(s);   int n;   puts("請輸入要進棧的個數:");   scanf("%d", &n);   while(n--)   {     int m;     scanf("%d", &m);     Push(s, m);   }   StackTraverse(s, visit);   puts("");   puts("8進棧后:");   Push(s, 8);   StackTraverse(s, visit);   puts("");   Pop(s, &e);   printf("出棧的元素是:%d/n", e);   printf("元素出棧后事實上并沒有清除,依然存在于內存空間,所謂的出棧只是指針移動,出棧的元素是%d/n", *s->top);//判斷出棧后元素是否還存在于內存中   Destroy(s);   return 0; } 

運行結果:

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久香蕉免费精品视频| 中文字幕亚洲天堂| 日韩中文有码在线视频| 亚洲美女www午夜| 亚洲色图av在线| 欧美福利在线观看| 91精品国产91久久久久久不卡| 日韩中文在线不卡| 亚洲精品成人久久久| 中文字幕日韩在线播放| 欧美日韩激情视频| 欧美日韩中文字幕在线| 91国自产精品中文字幕亚洲| 国产精品一区电影| 国产精品久久久久久久久久尿| 91超碰中文字幕久久精品| 欧美日本国产在线| 日韩欧美在线第一页| 久久久在线免费观看| 国产精品欧美风情| 日韩欧美在线字幕| 97精品伊人久久久大香线蕉| 欧美日韩国产中文精品字幕自在自线| 国产69精品久久久久久| 亚洲人在线观看| 欧美理论电影在线播放| 在线成人免费网站| 日韩精品视频在线播放| 国产精品无av码在线观看| 久久久久久久久久久免费| 疯狂做受xxxx高潮欧美日本| 最新亚洲国产精品| 91国产视频在线播放| 亚洲成人精品久久久| 欧美日韩视频免费播放| 欧美日本在线视频中文字字幕| 久久伊人免费视频| 国产精品极品尤物在线观看| 国产精品对白刺激| 欧美日韩精品国产| 日韩中文字幕欧美| 精品久久久久国产| 亚洲欧洲美洲在线综合| 国产在线视频91| 国产成人精品久久二区二区91| 国产精品美乳一区二区免费| 激情懂色av一区av二区av| 亚洲欧洲美洲在线综合| 亚洲精品720p| 91久久国产综合久久91精品网站| 国产精品福利在线观看网址| 国产一区二区香蕉| 97香蕉久久超级碰碰高清版| 精品色蜜蜜精品视频在线观看| 国产精品久久久久久网站| 国产精品一二三视频| 久久这里只有精品视频首页| 国产免费一区二区三区在线观看| 国产精品老牛影院在线观看| 欧日韩不卡在线视频| 搡老女人一区二区三区视频tv| 国产精品久久久一区| 深夜福利一区二区| 欧美午夜激情在线| 91精品国产高清久久久久久| 欧美国产第二页| 亚洲精品日韩激情在线电影| 久久成人精品一区二区三区| 国产精品亚洲精品| 亚洲自拍偷拍第一页| 超碰日本道色综合久久综合| 亚洲欧美日韩精品久久奇米色影视| 91视频88av| 国产在线98福利播放视频| 亚洲网站在线观看| 亚洲一级黄色片| 亚洲乱码一区av黑人高潮| 亚洲国产欧美一区二区三区同亚洲| 日韩一区二区三区xxxx| 国产亚洲视频在线| 亚洲欧美中文日韩在线v日本| 91精品视频网站| 亚洲国产精品大全| 国内精久久久久久久久久人| 91精品国产色综合久久不卡98口| 92看片淫黄大片欧美看国产片| 欧美日韩一区二区在线播放| 欧美日韩美女视频| 久久亚洲私人国产精品va| 国产精品高潮呻吟久久av无限| 有码中文亚洲精品| 亚洲乱码一区av黑人高潮| 9.1国产丝袜在线观看| 亚洲欧洲激情在线| 亚洲成人精品久久| 国产自摸综合网| 久久成人这里只有精品| 全亚洲最色的网站在线观看| 日韩免费高清在线观看| 欧美激情日韩图片| 日韩成人在线电影网| 欧美亚洲第一区| 欧美小视频在线观看| www.亚洲男人天堂| 国产精品国产三级国产aⅴ9色| 亚洲大胆人体在线| 日韩不卡在线观看| 亚洲黄页网在线观看| 中文字幕亚洲国产| 青青久久av北条麻妃海外网| 在线播放日韩专区| 亚洲精品第一国产综合精品| 国产剧情久久久久久| 亚洲精品自在久久| 欧美精品免费看| 57pao精品| 精品国产一区二区三区久久久| 精品国产欧美一区二区三区成人| 538国产精品一区二区在线| 青草青草久热精品视频在线网站| 亚洲黄页网在线观看| 亚洲男人天堂2023| 久久久久国产一区二区三区| 精品免费在线视频| 97视频在线观看网址| 精品国产鲁一鲁一区二区张丽| 欧美与黑人午夜性猛交久久久| 4438全国成人免费| 亚洲精品视频免费| 夜夜嗨av一区二区三区免费区| 91国语精品自产拍在线观看性色| 国产欧美婷婷中文| 亚洲精品动漫久久久久| 国产精品一区二区三区毛片淫片| 久热精品视频在线免费观看| 亚洲综合中文字幕在线| 一本大道久久加勒比香蕉| 91超碰中文字幕久久精品| 一区二区三区国产视频| 欧美日韩激情视频| 欧美极品欧美精品欧美视频| 欧美在线免费观看| 日韩成人在线视频观看| 久久久久久久网站| 久久影视免费观看| 欧美成人中文字幕在线| 国产精品爱久久久久久久| 95av在线视频| 久久韩剧网电视剧| 色综合久久久久久中文网| 欧洲成人午夜免费大片| 国产精品日韩在线观看| 日韩中文字幕在线免费观看| 久久精品国产综合| 国产91热爆ts人妖在线| 海角国产乱辈乱精品视频| 国产一区二区av| 91美女片黄在线观看游戏| 国产美女被下药99| 国产成人一区二| 韩国精品久久久999| 久久人人爽人人爽爽久久| 亚洲天堂av在线免费观看| 国产成+人+综合+亚洲欧洲|