欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)結(jié)構(gòu) 棧的操作實(shí)例詳解

 更新時間:2017年06月27日 16:56:04   投稿:lqh  
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 順序棧的定義、初始化、空棧判斷、入棧、出棧操作的相關(guān)資料,需要的朋友可以參考下

數(shù)據(jù)結(jié)構(gòu) 棧的操作實(shí)例詳解

說明:

    往前學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu),想運(yùn)行一個完整的順序棧的程序都運(yùn)行不了,因?yàn)闀辖o的都是一部分一部分的算法,并沒有提供一個完整可運(yùn)行的程序,聽了實(shí)驗(yàn)課,自己折騰了一下,總算可以寫一個比較完整的順序棧操作的小程序,對于棧也慢慢開始有了感覺。下面我會把整個程序拆開來做說明,只要把這些代碼放在一個文件中,用編譯器就可以直接編譯運(yùn)行了。

一、實(shí)現(xiàn)

1.程序功能

  關(guān)于棧操作的經(jīng)典程序,首當(dāng)要提及進(jìn)制數(shù)轉(zhuǎn)換的問題,利用棧的操作,就可以十分快速地完成數(shù)的進(jìn)制轉(zhuǎn)換。

2.預(yù)定義、頭文件導(dǎo)入和類型別名

    代碼如下:

#include<stdio.h>
#include<stdlib.h>
#define OVERFLOW -1
#define ERROR 0
#define FALSE 0
#define TRUE 1
#define OK 1
 
typedef int ElemType;
typedef int Status;

    除了兩個頭文件的導(dǎo)入是必須的之外,下面做兩點(diǎn)說明:

(1)其余的常量定義都是可選的,為的就是在下面的代碼書寫過程中可以盡量使用英文來表達(dá)程序的意思,而不是在代碼的實(shí)現(xiàn)過程中直接使用數(shù)字,依個人喜歡,也可以直接使用數(shù)字;

(2)使用typedef做類型的別名也僅僅是為了程序中代碼的意思更加清晰明了而已,實(shí)際也可以不這樣使用;

3.順序棧的定義 

   代碼如下:

typedef struct{
  ElemType *elem;   //存儲空間的基址
  int top;      //棧頂元素的下一個元素,簡稱棧頂位標(biāo)
  int size;      //當(dāng)前分配的存儲容量,作用看入棧操作就可以知道
  int increment;   //擴(kuò)容時,增加的存儲容量,作用看入棧操作就可以知道
} SqStack;         //順序棧名稱

4.棧的初始化

    代碼如下:

Status InitStack_Sq(SqStack &S, int size, int inc){   //接受3個參數(shù),&S是對結(jié)構(gòu)體的引用
  S.elem = (ElemType*)malloc(size*sizeof(ElemType)); //分配存儲空間
  if(S.elem == NULL) return OVERFLOW;   //判斷上一步分配存儲空間是否成功
  S.top = 0;      //置S為空棧,S.top為0即表示棧為空棧
  S.size = size;    //棧的空間初始容量值
  S.increment = inc;  //棧的空間初始增量值(如果需要擴(kuò)容)
  return OK;    //上面的執(zhí)行正常,返回OK
}

5.空棧的判斷

    代碼如下:

Status StackEmpty_Sq(SqStack S){
  if(S.top == 0)
    return TRUE;
  else
    return FALSE;
}
//空棧的決斷是,如果棧為空就返回1,否則就返回0,當(dāng)然可以不這樣規(guī)定;
//至于為什么要做空棧的判斷,自然是有原因的,下面再看程序的代碼時就可以知道了。

6.入棧

    代碼如下:

Status Push_Sq(SqStack &S, ElemType e){  //將元素e壓入棧,這里e只是一個形參而已
  ElemType *newbase;    //定義中間變量
  if(S.top>= S.size){    //S.top如果指向最后一個不存儲元素的地址時,即S.top大于
    newbase = (ElemType*)realloc(S.elem, //等于S.size時,就表示棧滿了
  (S.size + S.increment)*sizeof(ElemType)); //通過realloc動態(tài)擴(kuò)容
   
  if(NULL == newbase) return OVERFLOW; //判斷擴(kuò)容是否成功
  S.elem = newbase;   //擴(kuò)容成功后才將中間變量的值指向S.elem,防止擴(kuò)容失敗時,
  S.size = S.size + S.increment;   //S.elem指向一個不是原來的位置
  }
  S.elem[S.top] = e;  //將e元素入棧
  S.top++;       //使S.top加1,表示指向的是棧頂位標(biāo)
  return OK;      //上面操作正常后返回1
}

7.出棧

    代碼如下:

Status Pop_Sq(SqStack &S, ElemType &e){  //棧頂元素出棧,賦給元素e
  if(0 == S.top) return ERROR;  
  e = S.elem[--S.top];  //e出棧,并將S.top減1
  return OK;
}

8.進(jìn)制轉(zhuǎn)換的函數(shù)

    其實(shí)上面的步驟操作都是為了創(chuàng)建一個順序棧和定義順序棧的操作而已,并對可能出現(xiàn)的各種情況做一些相應(yīng)的舉措,完畢后,下面就要使用上面創(chuàng)建的順序棧以及棧的操作接口了,即在數(shù)制轉(zhuǎn)換函數(shù)(這里是十進(jìn)制轉(zhuǎn)八進(jìn)制)中使用上面的操作接口,代碼如下:

void Converstion(int N){
  SqStack S;
  ElemType e;
  InitStack_Sq(S, 10, 5);  //棧S的初始容量置為10,每次擴(kuò)容容量為5
   
  while(N != 0){
    Push_Sq(S, N%8);  //將N除以8的余數(shù)入棧
    N /= 8;      //N取值為其除以8的商
  }             //理論基礎(chǔ)為除8取余法
   
  while(StackEmpty_Sq(S) == FALSE){
    Pop_Sq(S, e);  //依次輸出棧中的余數(shù),并賦給元素e
    printf("%d", e); //打印元素
  }

9.main函數(shù)

    進(jìn)制轉(zhuǎn)換函數(shù)調(diào)用棧操作的接口函數(shù),以實(shí)現(xiàn)在數(shù)制轉(zhuǎn)換過程中棧的操作;main函數(shù)調(diào)用數(shù)制轉(zhuǎn)換函數(shù),以實(shí)現(xiàn)數(shù)制的轉(zhuǎn)換,代碼如下:

int main(void){
  printf("Enter a number:");scanf("%d",&num);
  Converstion(num);
  printf("\n");
}

二、執(zhí)行

    有了上面的代碼后,就可以在編譯器中編譯執(zhí)行了,這里我是用c free 5來進(jìn)行程序代碼的編譯:

(1)輸入的數(shù)為1348時的結(jié)果:

(2)輸入的數(shù)為2526時的結(jié)果:

三、完整的代碼

    下面把代碼都放在一起:

#include<stdio.h>
#include<stdlib.h>
#define OVERFLOW -1
#define ERROR 0
#define FALSE 0
#define TRUE 1
#define OK 1
 
typedef int ElemType;
typedef int Status;
 
typedef struct{
  ElemType *elem;
  int top;
  int size;
  int increment;
} SqStack;
 
Status InitStack_Sq(SqStack &S, int size, int inc){
  S.elem = (ElemType*)malloc(size*sizeof(ElemType));
  if(S.elem == NULL) return OVERFLOW;
  S.top = 0;
  S.size = size;
  S.increment = inc;
  return OK;
}
 
Status StackEmpty_Sq(SqStack S){
  if(S.top == 0)
    return TRUE;
  else
    return FALSE;
}
 
Status Push_Sq(SqStack &S, ElemType e){
  ElemType *newbase;
  if(S.top>= S.size){
    newbase = (ElemType*)realloc(S.elem,
  (S.size + S.increment)*sizeof(ElemType));
   
  if(NULL == newbase) return OVERFLOW;
  S.elem = newbase;
  S.size = S.size + S.increment;
  }
  S.elem[S.top] = e;
  S.top++;
  return OK;
}
 
Status Pop_Sq(SqStack &S, ElemType &e){
  if(0 == S.top) return ERROR;
  e = S.elem[--S.top];
  return OK;
}
 
void Converstion(int N){
  SqStack S;
  ElemType e;
  InitStack_Sq(S, 10, 5);
   
  while(N != 0){
    Push_Sq(S, N%8);
    N /= 8;
  }
   
  while(StackEmpty_Sq(S) == FALSE){
    Pop_Sq(S, e);
    printf("%d", e);
  }
}
 
int main(void){
  int num;
  printf("Enter a number:");scanf("%d",&num);
  Converstion(num);
  printf("\n");
}

相關(guān)文章

  • C語言時間函數(shù)的ctime()和gmtime()你了解嗎

    C語言時間函數(shù)的ctime()和gmtime()你了解嗎

    這篇文章主要為大家詳細(xì)介紹了C語言時間函數(shù)的ctime()和gmtime(),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C語言常見的指針筆試題解析

    C語言常見的指針筆試題解析

    在我們學(xué)習(xí)指針之后,應(yīng)該在實(shí)際應(yīng)用中去理解和掌握它,畢竟實(shí)踐才是檢驗(yàn)真理的唯一標(biāo)準(zhǔn),我們以后在找工作的過程中免不了會遇到與指針相關(guān)的試題,本篇文章可以幫助我們提前了解一些常見的指針考點(diǎn),需要的可以了解一下
    2022-10-10
  • C++ 實(shí)例之九宮格廣度優(yōu)先遍歷

    C++ 實(shí)例之九宮格廣度優(yōu)先遍歷

    這篇文章主要介紹了C++ 實(shí)例之九宮格廣度優(yōu)先遍歷的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言中循環(huán)語句練習(xí)實(shí)例

    C語言中循環(huán)語句練習(xí)實(shí)例

    大家好,本篇文章主要講的是C語言中循環(huán)語句練習(xí)實(shí)例,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • C++中mutable與volatile的深入理解

    C++中mutable與volatile的深入理解

    這篇文章主要給的阿加介紹了關(guān)于C++中mutable與volatile的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • 基于C++實(shí)現(xiàn)的哈夫曼編碼解碼操作示例

    基于C++實(shí)現(xiàn)的哈夫曼編碼解碼操作示例

    這篇文章主要介紹了基于C++實(shí)現(xiàn)的哈夫曼編碼解碼操作,結(jié)合實(shí)例形式分析了C++實(shí)現(xiàn)的哈夫曼編碼解碼相關(guān)定義與使用技巧,需要的朋友可以參考下
    2018-04-04
  • c++ 指針與引用的區(qū)別介紹及使用說明

    c++ 指針與引用的區(qū)別介紹及使用說明

    指針與引用看上去完全不同(指針用操作符*和->,引用使用操作符.),但是它們似乎有相同的功能,感興趣的朋友可以了解下啊,或許本文對你有所幫助,好了,話不多說,切入正題
    2013-01-01
  • C++設(shè)計類不能被繼承的方法實(shí)例講解

    C++設(shè)計類不能被繼承的方法實(shí)例講解

    在Java 中定義了關(guān)鍵字final,被final修飾的類不能被繼承,C++中如何實(shí)現(xiàn),下面我們來看一個例子
    2013-12-12
  • C++11系列學(xué)習(xí)之列表初始化

    C++11系列學(xué)習(xí)之列表初始化

    這篇文章主要介紹了C++11系列學(xué)習(xí)之列表初始化,標(biāo)準(zhǔn)初始化方式太過繁雜,限制偏多,因此在新標(biāo)準(zhǔn)中統(tǒng)一了初始化方,為了讓初始化具有確定的效果,于是提出了列表初始化概念,下文我們就一起來學(xué)習(xí)該詳細(xì)內(nèi)容介紹吧
    2022-04-04
  • 一篇文章讓你徹底明白c++11增加的變參數(shù)模板

    一篇文章讓你徹底明白c++11增加的變參數(shù)模板

    C++11的新特性--可變模版參數(shù)(variadic templates)是C++11新增的最強(qiáng)大的特性之一,它對參數(shù)進(jìn)行了高度泛化,它能表示0到任意個數(shù)、任意類型的參數(shù),這篇文章主要給大家詳細(xì)介紹了關(guān)于c++11增加的變參數(shù)模板的相關(guān)資料,需要的朋友可以參考下
    2021-08-08

最新評論