【Weiss】【第03章】队列例程

前几个例程还是相当简单的,把链表即时改了一下就是队列了。

还有想了一下,决定这种例程的代码放法是:先把测试代码默认折叠放在前面,然后把实现代码默认展开放在后面。

测试代码如下:

 1 #include <iostream>
 2 #include "queue.cpp"
 3 using namespace std;
 4 using namespace queue;
 5 template class Queue<int>;
 6 int main(void)
 7 {
 8     Queue<int> number;
 9
10     //测试插入
11     cout << "/*additem()*/" << endl;
12     number.enqueue(2);
13     number.enqueue(3);
14     number.enqueue(5);
15     number.enqueue(7);
16     number.enqueue(11);
17     number.traverse();
18     cout << "\n/*end*/\n\n" << flush;
19
20     //测试获取长度
21     cout << "/*length()*/" << endl;
22     cout << number.size() << endl;
23     cout << "/*end*/\n\n" << flush;
24
25     //测试获得头元素
26     cout << "/*getfirst()*/" << endl;
27     cout << number.getfirst() << endl;
28     cout << "/*end*/\n\n" << flush;
29
30     //测试获得尾元素
31     cout << "/*getfirst()*/" << endl;
32     cout << number.getlast() << endl;
33     cout << "/*end*/\n\n" << flush;
34
35     //测试出队
36     cout << "/*remove()*/" << endl;
37     number.dequeue();
38     number.dequeue();
39     number.traverse();
40     cout << "\n/*end*/\n\n" << flush;
41
42     //测试清空,并测试从空表中出队
43     cout << "/*clear(),remove()*/" << endl;
44     number.clear();
45     number.dequeue();
46     cout << "/*end*/\n\n" << flush;
47
48     system("pause");
49 }

queue_driver

队列实现代码如下:

  1 #include <iostream>
  2 using namespace std;
  3 #ifndef QUEUE
  4 #define QUEUE
  5
  6 namespace queue
  7 {
  8
  9 //节点模板
 10 template <typename T> struct Node
 11 {
 12     Node<T>() : next(nullptr){}
 13     Node<T>(const T &item, Node<T>* ptr = nullptr) : data(item), next(ptr){}
 14     T data;
 15     Node<T>* next;
 16 };
 17 //头节点及主体操作
 18 template <typename T> class Queue
 19 {
 20 //构造函数
 21 public:
 22     Queue<T>() : length(0), front(nullptr), rear(nullptr){}
 23 //接口
 24 public:
 25     //返回长度
 26     unsigned int size()const{ return length; }
 27     //返回头指针
 28     Node<T>* begin()const{ return front; }
 29     //判断是否为空
 30     bool empty()const{ return length == 0; }
 31     //获得头元素
 32     T getfirst()const{ return front->data; }
 33     //获得尾元素
 34     T getlast()const{ return rear->data; }
 35     //#查找元素所在地址
 36     Node<T>* find(const T &item)const;
 37     //#入队,插入队尾
 38     bool enqueue(const T &item);
 39     //#出队,删除队首元素
 40     bool dequeue();
 41     //#遍历并输出队列元素
 42     void traverse()const;
 43     //#清空队列
 44     void clear();
 45
 46 //辅助函数
 47 private:
 48     //#查找元素前驱
 49     Node<T>* find_prev(const T& item)const;
 50 //数据
 51 private:
 52     unsigned int length;
 53     Node<T>* front;
 54     Node<T>* rear;
 55 };
 56
 57 //如果元素为头元素或元素不存在则返回nullptr,否则返回前驱
 58 template <typename T> Node<T>* Queue<T>::find_prev(const T& item)const
 59 {
 60     if (length == 0)
 61         return nullptr;
 62     if (front->data == item)
 63         return nullptr;
 64     for (Node<T>* iter = front; iter->next != nullptr; iter = iter->next)
 65     {
 66         if (iter->next->data == item)
 67             return iter;
 68     }
 69     return nullptr;
 70 }
 71 //调用find_prev,如果元素存在则返回地址,不存在则返回nullptr
 72 template <typename T> Node<T>* Queue<T>::find(const T &item)const
 73 {
 74     Node<T>* iter = find_prev(item);
 75     if (length == 0)
 76         return nullptr;
 77     if (front->data == item)
 78         return front;
 79     return iter->next;
 80 }
 81 template <typename T> bool Queue<T>::enqueue(const T &item)
 82 {
 83     Node<T>* pnew = new Node<T>(item);
 84     if (length == 0)
 85         front = rear = pnew;
 86     else
 87     {
 88         rear->next = pnew;
 89         rear = rear->next;
 90     }
 91     ++length;
 92     return true;
 93 }
 94 template <typename T> bool Queue<T>::dequeue()
 95 {
 96     if (length == 0)
 97     {
 98         cout << "No data!" << endl;
 99         return false;
100     }
101     Node<T>* save = front;
102     front = front->next;
103     //如果出队后队列为空,则尾指针同时置空
104     if (length == 1)
105         rear = nullptr;
106     delete save;
107     --length;
108     return true;
109 }
110 template <typename T> void Queue<T>::traverse()const
111 {
112     if (length != 0)
113     {
114         for (Node<T>* iter = front; iter != nullptr; iter = iter->next)
115             cout << iter->data << ends;
116     }
117 }
118 template <typename T> void Queue<T>::clear()
119 {
120     Node<T>* iter;
121     while (front != nullptr)
122     {
123         iter = front;
124         front = front->next;
125         delete iter;
126     }
127     front = rear = nullptr;
128     length = 0;
129 }
130
131 }
132 #endif
时间: 2024-08-07 21:20:28

【Weiss】【第03章】队列例程的相关文章

【Weiss】【第03章】练习3.25:数组模拟队列

[练习3.25] 编写实现队列的例程,使用 a.链表 b.数组 Answer: 在这章一开头就已经写了个链表的队列例程了,所以实际上只要做b小题就可以. 数组模拟队列和链表的两点小不同是: ①.数组空间有限,入队需要检测数组是否已经满 ②.数组经过几次操作后,rear可能绕回front前面,所以许多操作都要用模来实现. 测试代码: 1 #include <iostream> 2 #include "queue.h" 3 using namespace std; 4 usin

异步编程系列第03章 自己写异步代码

p { display: block; margin: 3px 0 0 0; } --> 写在前面 在学异步,有位园友推荐了<async in C#5.0>,没找到中文版,恰巧也想提高下英文,用我拙劣的英文翻译一些重要的部分,纯属娱乐,简单分享,保持学习,谨记谦虚. 如果你觉得这件事儿没意义翻译的又差,尽情的踩吧.如果你觉得值得鼓励,感谢留下你的赞,愿爱技术的园友们在今后每一次应该猛烈突破的时候,不选择知难而退.在每一次应该独立思考的时候,不选择随波逐流,应该全力以赴的时候,不选择尽力而

第03章-VTK系统概述(1)

[译者:这个系列教程是以Kitware公司出版的<VTK User's Guide -11th edition>一书作的中文翻译(出版时间2010年,ISBN: 978-1-930934-23-8),由于时间关系,我们不能保证每周都能更新本书内容,但尽量做到一周更新一篇到两篇内容.敬请期待^_^.欢迎转载,另请转载时注明本文出处,谢谢合作!同时,由于译者水平有限,出错之处在所难免,欢迎指出订正!] 本章旨在介绍VTK系统的总体概述,并讲解运用C++.Java.Tcl和Python等语言进行VT

&lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第03章 | 字符串

第03章: 使用字符串 ------ 支持的操作 索引 切片 增加元素 删除元素 更新元素 查找元素(检查某个元素是否是序列中的一员) 序列长度 最大值 最小值 其他内建函数 >>> website='http://www.python.org' >>> website[-3:]='com' #此操作不合法,因为字符串是不变,不能做修改 Traceback (most recent call last): File "<pyshell#162>&q

JavaScript权威指南第03章 类型、值和变量

类型.值和变量 数据类型分类: 原始类型(primitive type):数字 字符串 布尔值 null undefined 对象类型(object type): 对象是属性的集合,每个属性都由"名/值"对构成. javascript解释器有自己的内存管理机制,可以自动对内存进行垃圾回收. 3.1数字 javascript不区分浮点和整型,所有的数字都是按照浮点型处理. 3.1.1整型直接量 3.1.2浮点型直接量 3.1.3算数运算 3.1.4二进制浮点数和四舍五入错误 当进行小数进

JavaScript权威指南第03章 类型、值和变量(2)

题目链接:https://oj.leetcode.com/problems/set-matrix-zeroes/ Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. 一个个找肯定会超时,我们可以分别用一个行向量和一个列向量进行维护.这样O(m*n) 能出来 class Solution { public: void setZeroes(vector<vector

第03章-VTK系统概述(3)

[译者:这个系列教程是以Kitware公司出版的<VTK User's Guide -11th edition>一书作的中文翻译(出版时间2010年,ISBN: 978-1-930934-23-8),由于时间关系,我们不能保证每周都能更新本书内容,但尽量做到一周更新一篇到两篇内容.敬请期待^_^.欢迎转载,另请转载时注明本文出处,谢谢合作!同时,由于译者水平有限,出错之处在所难免,欢迎指出订正!] [本节对应原书中的第29页至第39页] 3.2创建VTK应用程序 本章内容包括利用Tcl,C++

groovy入门 第03章 字符串和正则表达式

字符串和正则表达式 3.1字符串字面值 可以使用单引号.双引号.三引号来封装字符串. 使用单引号封装的字符串就是字符串序列本身. 使用双引号可以嵌套单引号,并可以将表达式包含进来. 使用三引号可以包含多行文本. def age=25 'My age is ${age}'            // 输出My age is ${age} "My age is ${age}"           //输出My age is 25 """'My age is $

第03章-VTK系统概述(2)

CPU: I3 2.4Ghz 4核,内存8G 方式一:采用其原生接口操作 JVM:-Xms1024m -Xmx1024m -Xmn512m-XX:PermSize=128m -XX:MaxPermSize=256m 4000节点(50个属性),4000关系:1秒,其间cpu使用率25%,761M 8000节点(50个属性),8000关系:2秒,其间cpu使用率25%,829M 16000节点(50个属性),16000关系:5秒,其间cpu使用率25,983M 24000节点(50个属性),240