队列

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
#include <vector>
#include <iostream>

using namespace std;

template <typename T> class Queue{
private:
vector<T> qqueue;
int size;
public:
Queue();
~Queue();
void push(T e);
T pop();
int getSize()const;
int isEmpty()const;
T getFront();
T getBack();
};

template <typename T>
Queue<T>::Queue(){
this->size = 0;
}

template <typename T>
Queue<T>::~Queue(){

}

template <typename T>
void Queue<T>::push(T e){
this->qqueue.push_back(e);
this->size++;
}

template <typename T>
T Queue<T>::pop(){
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
T ret = this->qqueue[0];
for(int i=0; i<this->size-1; i++)
this->qqueue[i] = this->qqueue[i+1];
this->qqueue.erase(this->qqueue.begin() + this->size - 1);
this->size --;
return ret;
}

template <typename T>
int Queue<T>::getSize()const{
return this->size;
}

template <typename T>
int Queue<T>::isEmpty()const{
return (this->size == 0);
}

template <typename T>
T Queue<T>::getFront(){
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
return this->qqueue[0];
}

template <typename T>
T Queue<T>::getBack(){
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
return this->qqueue[this->size-1];
}


int main(){
Queue<int> test;
cout << "The size: " << test.getSize() << endl;
cout << "Is Empty? " << test.isEmpty() << endl;
for(int i=0; i<10; i++)
{
cout << "Push: " << i << endl;
test.push(i);
}
cout << "The size: " << test.getSize() << endl;
for(int i=0; i<5; i++)
cout << "Pop: " << test.pop() << endl;
cout << "The size: " << test.getSize() << endl;
cout << "Is Empty? " << test.isEmpty() << endl;
cout << "Now the front: " << test.getFront() << endl;
cout << "Now the back: " << test.getBack() << endl;
return 0;
}
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
123
124
125
126
127
#include <iostream>
using namespace std;

template <typename T>
struct Node
{
T data;
Node<T>* next;
};


template <typename T> class LinkedQueue{
private:
int size;
Node<T>* QueueHead;
public:
LinkedQueue();
~LinkedQueue();
int getSize()const;
bool isEmpty()const;
T getFront()const;
T getBack()const;
void push(T e);
T pop();
};

template <typename T>
LinkedQueue<T>::LinkedQueue(){
this->size = 0;
this->QueueHead = new Node<T>;
this->QueueHead->next = NULL;
}

template <typename T>
LinkedQueue<T>::~LinkedQueue(){
while(this->size > 0)
{
this->pop();
}
delete this->QueueHead;
}


template <typename T>
int LinkedQueue<T>::getSize()const{
return this->size;
}

template <typename T>
bool LinkedQueue<T>::isEmpty()const{
return (this->size == 0);
}

template <typename T>
T LinkedQueue<T>::getFront()const{
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
return this->QueueHead->next->data;
}

template <typename T>
T LinkedQueue<T>::getBack()const{
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
Node<T>* cur = this->QueueHead;
while(cur->next != NULL)
{
cur = cur->next;
}
return cur->data;
}


template <typename T>
void LinkedQueue<T>::push(T e){
Node<T>* cur = this->QueueHead;
while(cur->next != NULL)
{
cur = cur->next;
}
Node<T>* ans = new Node<T>;
ans->data = e;
ans->next = NULL;
cur->next = ans;
this->size++;
}

template <typename T>
T LinkedQueue<T>::pop(){
if(this->size == 0)
{
cout << "isEmpty Wrong" << endl;
return -1;
}
Node<T>* delNode = this->QueueHead->next;
this->QueueHead->next = delNode->next;
T retdata = delNode->data;
delete delNode;
this->size--;
return retdata;
}


int main(){
LinkedQueue<int> test;
cout << "The size: " << test.getSize() << endl;
cout << "Is Empty? " << test.isEmpty() << endl;
for(int i=0; i<10; i++)
{
cout << "Push: " << i << endl;
test.push(i);
}
cout << "The size: " << test.getSize() << endl;
for(int i=0; i<5; i++)
cout << "Pop: " << test.pop() << endl;
cout << "The size: " << test.getSize() << endl;
cout << "Is Empty? " << test.isEmpty() << endl;
cout << "Now the front: " << test.getFront() << endl;
cout << "Now the back: " << test.getBack() << endl;
return 0;
}
Donate? comment?