棧鏈式結構簡單操作

Diy_os發表於2015-10-19
關於棧的鏈式儲存結構,下面用的是單連結串列頭插法建立棧,因為頭插法的特點是在頭結點(frist)與NULL空結點(first ->next)之間插入各結點,儲存資料的入棧順序和出棧順序是相反的,和棧的
特點很相似,工作指標如top指標一樣,始終指向棧頂(第一個結點)。下程式碼如有不當之處,請指正!

點選(此處)摺疊或開啟

  1. #include<iostream>
  2. //#include<stdlib.h>
  3. using namespace std;
  4. struct Stack {

  5.     int data;
  6.     struct Stack *next;
  7. };

  8. Stack *CreatStack() {

  9.     Stack *p;
  10.     p = new Stack; //p = (Stack *)malloc(sizeof(Stack));
  11.     p->data = NULL;  //頭結點不存放資料域
  12.     p->next = NULL; //棧底
  13.     return p;
  14. }

  15. Stack *PushStack(Stack *p) {

  16.     Stack *q;

  17.     cout << "進棧順序:" << endl;
  18.                                     //下面用頭插法構建鏈式棧,和單連結串列的頭插法沒有區別
  19.     for (int i = 0; i < 9; i++) {

  20.         q = new Stack;   
  21.         q->data = i;
  22.         cout << q->data << "-->";
  23.         q->next = p->next;
  24.         p->next = q;
  25.     }
  26.     cout << "進棧結束" << endl;
  27.     return p;
  28. }

  29. void PrintStack(Stack *p) {  //出棧

  30.     cout << "出棧順序:" << endl;

  31.     p = p->next;

  32.     for (p->next; p != NULL; p = p->next) {

  33.         cout << p->data << "-->";
  34.     }
  35.     cout << "出棧結束" << endl;
  36. }

  37. void InsertStack(Stack *first,int x) {    //在棧頂插入結點


  38.     Stack *p;
  39.     p = new Stack;
  40.     p->data = x;
  41.     p->next = first->next;
  42.     first->next = p;

  43. }

  44. void DestoryStack(Stack *first) {  //銷燬棧

  45.      do{

  46.         Stack *p;
  47.         p = first;
  48.         first = first->next;
  49.         delete p;  //該步一定要在上面步驟之後
  50.         p = NULL;  //避免出現迷途指標
  51.         

  52.      } while (first != NULL);

  53.     cout << "鏈棧已銷燬" << endl;
  54. }

  55. int main() {

  56.     Stack *p,*s;
  57.     p = CreatStack();
  58.     s = PushStack(p);
  59.     //InsertStack(s, 11);
  60.     DestoryStack(s);
  61.     //PrintStack(s);
  62. }

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29876893/viewspace-1814930/,如需轉載,請註明出處,否則將追究法律責任。

相關文章