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

C++中實現(xiàn)隊列類鏈式存儲與棧類鏈式存儲的代碼示例

 更新時間:2016年03月14日 17:48:26   作者:YoferZhang  
這篇文章主要介紹了C++中實現(xiàn)隊列類鏈式存儲與棧類鏈式存儲的代碼示例,通過注釋來說明,直接上代碼,簡單粗暴XD 需要的朋友可以參考下

隊列類鏈式存儲

代碼:
linkqueue.hpp 

// 隊列類 
 
#pragma once 
 
#include "linklist.hpp" 
 
template <typename T> 
class LinkQueue 
{ 
public: 
  LinkQueue(); 
  ~LinkQueue(); 
public: 
  int clear(); 
  int append(T &t); 
  int retieve(T &t); 
  int header(T &t); 
  int length(); 
protected: 
  LinkList<T> *m_list; 
}; 
 
template <typename T> 
LinkQueue<T>::LinkQueue() 
{ 
  m_list = new LinkList < T > ; 
} 
 
template <typename T> 
LinkQueue<T>::~LinkQueue() 
{ 
  clear(); 
  delete m_list; 
  m_list = NULL; 
} 
 
template <typename T> 
int LinkQueue<T>::clear() 
{ 
  T t; 
  while (m_list->getLen() > 0) { 
    m_list->del(0, t); 
  } 
  return 0; 
} 
 
template <typename T> 
int LinkQueue<T>::append(T &t) 
{ 
  return m_list->insert(t, m_list->getLen()); 
} 
 
template <typename T> 
int LinkQueue<T>::retieve(T &t) 
{ 
  return m_list->del(m_list->getLen() - 1, t); 
} 
 
template <typename T> 
int LinkQueue<T>::header(T &t) 
{ 
  return m_list->get(0, t); 
} 
 
template <typename T> 
int LinkQueue<T>::length() 
{ 
  return m_list->getLen(); 
} 

main.cpp 

// 隊列類測試程序 
 
#include <iostream> 
#include <cstdio> 
#include "linkqueue.hpp" 
 
using namespace std; 
 
struct Student 
{ 
  char name[32]; 
  int age; 
}; 
 
void play() 
{ 
  Student s1, s2, s3; 
  s1.age = 21; 
  s2.age = 22; 
  s3.age = 23; 
 
  LinkQueue<Student> lq; // 創(chuàng)建隊列 
  lq.append(s1); // 入隊列 
  lq.append(s2); 
  lq.append(s3); 
 
  Student tmp; 
  lq.header(tmp); 
  cout << "header of queue: " << tmp.age << endl; 
  cout << "length of queue: " << lq.length() << endl; 
 
  while (lq.length() > 0) { 
    lq.retieve(tmp); 
    cout << tmp.age << " "; 
  } 
  cout << endl; 
 
  lq.clear(); 
 
} 
 
int main() 
{ 
  play(); 
 
  return 0; 
} 


棧類鏈式存儲

linkstack.hpp 

// 棧類 
 
#pragma once 
 
#include "linklist.hpp" 
 
template <typename T> 
class LinkStack 
{ 
public: 
  LinkStack(); 
  ~LinkStack(); 
public: 
  int clear(); 
  int push(T &t); 
  int pop(T &t); 
  int top(T &t); 
  int size(); 
protected: 
  LinkList<T> *m_list; 
}; 
 
template <typename T> 
LinkStack<T>::LinkStack() 
{ 
  m_list = new LinkList < T > ; 
} 
 
template <typename T> 
LinkStack<T>::~LinkStack() 
{ 
  clear(); 
  delete m_list; 
  m_list = NULL; 
} 
 
template <typename T> 
int LinkStack<T>::clear() 
{ 
  T t; 
  while (m_list->getLen() > 0) { 
    m_list->del(0, t); 
  } 
 
  return 0; 
} 
 
template <typename T> 
int LinkStack<T>::push(T &t) 
{ 
  return m_list->insert(t, 0); 
} 
 
template <typename T> 
int LinkStack<T>::pop(T &t) 
{ 
  return m_list->del(0, t); 
} 
 
template <typename T> 
int LinkStack<T>::top(T &t) 
{ 
  return m_list->get(0, t); 
} 
 
template <typename T> 
int LinkStack<T>::size() 
{ 
  return m_list->getLen(); 
} 

main.cpp 

// 鏈式存儲棧類的測試程序 
 
#include <iostream> 
#include <cstdio> 
#include "linkstack.hpp" 
 
using namespace std; 
 
struct Student 
{ 
  char name[32]; 
  int age; 
}; 
 
void play() 
{ 
  Student s1, s2, s3; 
  s1.age = 21; 
  s2.age = 22; 
  s3.age = 23; 
 
  LinkStack<Student> ls; // 創(chuàng)建棧 
 
  // 入棧 
  ls.push(s1); 
  ls.push(s2); 
  ls.push(s3); 
 
  // 獲取棧頂元素 
  Student tmp; 
  ls.top(tmp); 
  cout << "top of stack: " << tmp.age << endl; 
  cout << "size of stack: " << ls.size() << endl; 
 
  // 出棧 
  while (ls.size() > 0) { 
    ls.pop(tmp); 
  } 
 
  ls.clear(); 
 
} 
 
int main() 
{ 
  play(); 
 
  return 0; 
} 

linklist.h 

// 鏈表類 
 
#pragma once 
 
#include <iostream> 
#include <cstdio> 
using namespace std; 
 
template <typename T> 
struct Node 
{ 
  T t; 
  Node<T> *next; 
}; 
 
template <typename T> 
class LinkList 
{ 
public: 
  LinkList(); 
  ~LinkList(); 
 
public: 
  int clear(); 
  int insert(T &t, int pos); 
  int get(int pos, T &t); 
  int del(int pos, T &t); 
  int getLen(); 
 
protected: 
  Node<T> *header; 
  int length; 
}; 
 
template <typename T> 
LinkList<T>::LinkList() 
{ 
  header = new Node < T > ; 
  header->next = NULL; 
  length = 0; 
} 
 
template <typename T> 
LinkList<T>::~LinkList() 
{ 
  Node<T> *tmp = NULL; 
 
  while (header) { 
    tmp = header->next; 
    delete header; 
    header = tmp; 
  } 
} 
 
template <typename T> 
int LinkList<T>::clear() 
{ 
  ~LinkList(); 
  LinkList(); 
  return 0; 
} 
 
template <typename T> 
int LinkList<T>::insert(T &t, int pos) 
{ 
  Node<T> *cur = NULL; 
 
  // 對pos的容錯處理 
  if (pos >= length) { 
    pos = length; 
  } 
 
  cur = header; 
  for (int i = 0; i < pos; ++i) { 
    cur = cur->next; 
  } 
 
  // 把上層應用的t結點緩存到容器中 
  Node<T> *node = new Node < T > ; 
  node->next = NULL; 
  node->t = t; // 把t緩存到容器中 
 
  node->next = cur->next; 
  cur->next = node; 
 
  ++length; 
 
  return 0; 
} 
 
template <typename T> 
int LinkList<T>::get(int pos, T &t) 
{ 
  Node<T> *cur = NULL; 
 
  if (pos >= length) { 
    return -1; 
  } 
 
  cur = header; 
  for (int i = 0; i < pos; ++i) { 
    cur = cur->next; 
  } 
 
  t = cur->next->t; // 把pos位置的結點賦值給t 
 
  return 0; 
} 
 
template <typename T> 
int LinkList<T>::del(int pos, T &t) 
{ 
  Node<T> *cur = NULL; 
 
  if (pos >= length) { 
    return -1; 
  } 
 
  cur = header; 
  for (int i = 0; i < pos; ++i) { 
    cur = cur->next; 
  } 
  Node<T> *ret = NULL; 
  ret = cur->next; 
  t = ret->t; // 把緩存的結點給上層應用t 
 
  // 刪除操作 
  cur->next = ret->next; 
  --length; 
  delete ret; // 注意釋放內存,因為insert的時候new Node<T> 
 
  return 0; 
} 
 
template <typename T> 
int LinkList<T>::getLen() 
{ 
  return length; 
} 

相關文章

  • c++ 移動構造相關總結

    c++ 移動構造相關總結

    這篇文章主要介紹了c++ 移動構造的相關資料,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下
    2021-02-02
  • C語言實現(xiàn)稀疏矩陣

    C語言實現(xiàn)稀疏矩陣

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)稀疏矩陣的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • C/C++實現(xiàn)獲取系統(tǒng)時間的示例代碼

    C/C++實現(xiàn)獲取系統(tǒng)時間的示例代碼

    C 標準庫提供了 time() 函數與 localtime() 函數可以獲取到當前系統(tǒng)的日歷時間。本文將通過一些簡單的示例為大家講講C++獲取系統(tǒng)時間的具體方法,需要的可以參考一下
    2022-12-12
  • C++ Primer中&、*符號的多重定義與int *p和int* p的區(qū)別講解

    C++ Primer中&、*符號的多重定義與int *p和int* p的區(qū)別講解

    今天小編就為大家分享一篇關于C++Primer中&、*符號的多重定義與int *p和int* p的區(qū)別講解,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • C++面試八股文之如何避免死鎖詳解

    C++面試八股文之如何避免死鎖詳解

    在C++中,鎖(Lock)是一種同步工具,用于保護共享資源,防止多個線程同時訪問,那么如何避免死鎖的情況出現(xiàn)呢,下面就為大家簡單講講
    2023-07-07
  • C++中的Reactor原理與實現(xiàn)

    C++中的Reactor原理與實現(xiàn)

    reactor設計模式是event-driven?architecture的一種實現(xiàn)方式,處理多個客戶端并發(fā)的向服務端請求服務的場景,每種服務在服務端可能由多個方法組成,這篇文章主要介紹了Reactor原理與實現(xiàn),需要的朋友可以參考下
    2022-07-07
  • C++如何通過ostringstream實現(xiàn)任意類型轉string

    C++如何通過ostringstream實現(xiàn)任意類型轉string

    再使用整型轉string的時候感覺有點棘手,因為itoa不是標準C里面的,而且即便是有itoa,其他類型轉string不是很方便。后來去網上找了一下,發(fā)現(xiàn)有一個好方法
    2013-09-09
  • C++實現(xiàn)ping程序實例

    C++實現(xiàn)ping程序實例

    這篇文章主要介紹了C++實現(xiàn)ping程序實例,涉及C++對于ICMP數據包的發(fā)送與回顯處理,具有一定的實用價值,需要的朋友可以參考下
    2014-10-10
  • C語言開發(fā)實現(xiàn)貪吃蛇小游戲

    C語言開發(fā)實現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細介紹了C語言開發(fā)實現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • 淺談C++類型轉化(運算符重載函數)和基本運算符重載(自增自減)

    淺談C++類型轉化(運算符重載函數)和基本運算符重載(自增自減)

    下面小編就為大家?guī)硪黄獪\談C++類型轉化(運算符重載函數)和基本運算符重載(自增自減)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06

最新評論