国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C++使用模板類實現鏈式棧

C++使用模板類實現鏈式棧

2021-09-02 16:06ChanJose C/C++

這篇文章主要為大家詳細介紹了C++使用模板類實現鏈式棧,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C++使用模板類實現鏈式棧的具體代碼,供大家參考,具體內容如下

一、實現程序:

1.Stack.h

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#ifndef Stack_h
#define Stack_h
 
template <class T>
class Stack {
public:
  Stack(){}; // 構造函數
  void Push(const T x); // 新元素進棧
  bool Pop(); // 棧頂元素出棧
  virtual bool getTop(T &x) const = 0; // 讀取棧頂元素,由x返回
  virtual bool isEmpty() const = 0; // 判斷棧空否
  // virtual bool isFull() const = 0; // 判斷棧滿否,因為鏈式棧不存在不滿的情況
  virtual int getSize() const = 0; // 計算棧中元素個數
};
 
 
#endif /* Stack_h */

2.LinkedStack.h

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#ifndef LinkedStack_h
#define LinkedStack_h
#include <iostream>
#include "Stack.h"
using namespace std;
 
template <class T>
struct LinkNode {
  T data;
  LinkNode<T> *link;
};
 
//類的前置聲明
template <class T>
class LinkedStack;
 
//友元函數的聲明
template <class T>
ostream& operator<<(ostream& out, LinkedStack<T>& s);
template <class T>
class LinkedStack: public Stack<T> {
public:
  LinkedStack(); // 構造函數
  ~LinkedStack();// 析構函數
  void Push(const T x); // 進棧
  bool Pop(); // 出棧
  bool getTop(T &x) const; // 讀取棧頂元素
  bool isEmpty()const; // 判斷棧是否為空
  int getSize()const; // 求棧的元素個數
  void makeEmpty(); // 清空棧的內容
  friend ostream& operator << <T>(ostream& out, LinkedStack<T>& s); // 重載輸出函數
private:
  LinkNode<T> *top; // 棧頂指針,即鏈頭指針
};
template <class T>
LinkedStack<T>::LinkedStack() {
  // 構造函數,置空棧
  top = new LinkNode<T>(); // 引入頭指針:不存放數據
  top->link = NULL;
}
template <class T>
LinkedStack<T>::~LinkedStack() {
  // 析構函數,釋放內存空間
  makeEmpty();
}
template <class T>
void LinkedStack<T>::Push(const T x) {
  // 進棧:將元素值x插入到鏈式棧的棧頂,即鏈頭
  LinkNode<T> *newNode = new LinkNode<T>(); // 創建包含x的新結點
  if(newNode == NULL) {
    cerr << "內存空間分配失敗!" << endl;
    exit(1);
  }
  newNode->data = x;
  newNode->link = top->link; // 指向頭指針的下一個結點:即棧中第一個存放有效數據的結點
  top->link = newNode; // 頭指針往前移
}
template <class T>
bool LinkedStack<T>::Pop() {
  // 出棧:刪除棧頂結點
  if(isEmpty())
    return false; // 棧空,不出棧
  LinkNode<T> *p = top->link; // 暫存棧頂元素
  top->link = p->link; // 棧頂指針退到新的棧頂位置
  delete p;
  p = NULL;
  return true;
}
 
template <class T>
bool LinkedStack<T>::getTop(T &x) const {
  // 讀取棧頂元素
  if(isEmpty())
    return false;
  x = top->link->data; // 棧不空,返回棧頂元素的值。這里top為頭指針,所以棧頂元素為:top->link
  return true;
}
 
template <class T>
bool LinkedStack<T>::isEmpty()const {
  // 判斷棧是否為空
  if(top->link == NULL) // 棧為空
    return true;
  return false;
}
 
template <class T>
int LinkedStack<T>::getSize()const {
  // 求棧的元素個數
  int len = 0;
  
  LinkNode<T> *current = top->link;
  while(current != NULL) {
    len++;
    current = current->link;
  }
  return len;
}
 
template <class T>
void LinkedStack<T>::makeEmpty() {
  // 清空棧的內容
  LinkNode<T> *current = top->link;
  while(current != NULL) {
    top->link = current->link; // 保存鏈式棧準備要刪除的結點的下一個結點,防止丟失
    delete current; // 釋放
    current = NULL; // 先指向空
    current = top->link; // 再指向剩下鏈表的首結點
  }
}
 
template <class T>
ostream& operator<<(ostream& out, LinkedStack<T>& s) {
  // 重載輸出函數
  LinkNode<T> *current = s.top->link;
  while(current != NULL) {
    out << current->data << " ";
    current = current->link;
  }
  return out;
}
#endif /* LinkedStack_h */

3.main.cpp

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include "LinkedStack.h"
using namespace std;
 
int main(int argc, const char * argv[]) {
  int n, x, choice, len; // val存儲值,choose存儲用戶的選擇
  bool finished = false;
  LinkedStack<int> L; // 對象
  
  while(!finished) {
    cout << "1:建棧:" << endl;
    cout << "2:進棧" << endl;
    cout << "3:出棧:" << endl;
    cout << "4:讀取棧頂元素:" << endl;
    cout << "5:棧是否為空:" << endl;
    cout << "6:棧中的元素個數:" << endl;
    cout << "7:清空棧的內容:" << endl;
    cout << "8:輸出棧中元素的值:" << endl;
    cout << "9:退出" << endl;
    cout << "請輸入你的選擇[1-9]:" << endl;
    cin >> choice;
    switch(choice) {
      case 1:
        cout << "請輸入要進棧的數的個數:";
        cin >> n;
        cout << "請輸入要進棧的數(以空格隔開):" << endl;
        for(int i=0; i < n; i++) {
          cin >> x;
          L.Push(x);
        }
        break;
      case 2:
        cout << "請輸入要進棧的數:";
        cin >> x;
        L.Push(x);
        break;
      case 3:
        if(L.Pop())
          cout << "出棧成功!" << endl;
        else
          cout << "棧為空!" << endl;
        break;
      case 4:
        if(L.getTop(x))
          cout << "棧頂元素的值為:" << x << endl;
        else
          cout << "棧為空!" << endl;
        break;
      case 5:
        if(L.isEmpty())
          cout << "棧為空!" << endl;
        else
          cout << "棧不為空!" << endl;
        break;
      case 6:
        len = L.getSize();
        cout << "棧中的元素個數為:" << len << endl;
        break;
      case 7:
        L.makeEmpty(); // 清空棧
        break;
      case 8:
        if(L.isEmpty())
          cout << "棧為空!" << endl;
        else
          cout << L << endl;
        break;
      case 9:
        finished = true;
        break;
      default:
        cout << "輸入錯誤,請重新輸入!" << endl;
    } // switch
  } // while
  return 0;
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/chuanzhouxiao/article/details/86081748

延伸 · 閱讀

精彩推薦
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 国产中文字幕一区 | 亚洲一区二区在线播放 | 黄色毛片在线观看 | 精品国产黄a∨片高清在线 成人欧美 | 一区二区三区在线观看视频 | 玖玖国产精品视频 | 91精品国产一区二区三区 | 麻豆一区 | 黄色免费av | 国产成年免费视频 | 亚洲色综合| 欧美一区高清 | 久久精品国产清自在天天线 | 欧美日韩久久久久 | 99精品一区二区 | 久色视频在线 | 91视频在线 | 精品国产欧美 | 国产高清av在线一区二区三区 | 成人中文网| 亚洲国产精品久久久 | 美女黄网| 碰碰视频 | www.久草.com| 中文二区| 日本涩涩视频 | 午夜av影院 | 午夜精品久久久久久久久久久久 | 亚洲一区二区三区在线 | 我和我的祖国电影在线观看免费版高清 | 91精品视频一区 | 欧美日一区| 国产日韩视频 | 中文字幕在线一区二区三区 | 欧美午夜精品久久久久久蜜 | 亚洲 自拍 另类 欧美 丝袜 | 国产在线三区 | 日日夜夜一区二区 | 亚洲高清日本 | 精品伊人久久 | 欧美中文字幕一区二区三区亚洲 |