C++队列中应该注意的一些问题
2016-05-11 17:29
351 查看
第一次在C++中写类,新手,见笑
#include<iostream.h>
#include<iostream>
template<typename T>
class Queue
{
private:
int maxsize,front,rear;
T *q;
public:
Queue()
{
q=new T[maxsize];
rear=front=0;
}
~Queue()
{
delete []q;
}
bool AddQ(T item);
bool Delete(T &item);
bool QFull();
bool QEmpty();
int getsize();
};
template<typename T>
bool Queue<T> ::AddQ(T item)
{
rear=(++rear)%maxsize;
if(rear==front)
{
printf("The Queue is full");
if(!front)
{
rear=maxsize;
}
else
{
rear=rear-1;
}
return false;
}
else
{
q[rear]=item;
return true;
}
}
template<typename T>
bool Queue<T> ::Delete(T &item)
{
if(front==rear)
{
printf("The queue is empty!");
return false;
}
else
{
front=front+1;
front=front%maxsize;
item=q[front];
return true;
}
}
template<typename T>
int Queue<T> ::getsize()
{
return rear-front;
}
1、首先吧,类应该写到.h文件中
2、其次应该写与类名一样的构造函数
Queue()
{
q=new T[maxsize];
rear=front=0;
}
3、template<typename T>
这样的话就可以不限制使用的数据类型了
4、class之后的{}应该加;
5、
bool AddQ(T item);
bool Delete(T &item);
bool QFull();
bool QEmpty();
int getsize();
在类外写这些函数时,每一个函数前应该加template<typename T>
6、还有一个问题:
Delete(T &item)
Add(T item)
为什么一个取地址为什么另一个不取地址
试了一下,好像暂时两个都可以运行
#include<iostream.h>
#include<iostream>
template<typename T>
class Queue
{
private:
int maxsize,front,rear;
T *q;
public:
Queue()
{
q=new T[maxsize];
rear=front=0;
}
~Queue()
{
delete []q;
}
bool AddQ(T item);
bool Delete(T &item);
bool QFull();
bool QEmpty();
int getsize();
};
template<typename T>
bool Queue<T> ::AddQ(T item)
{
rear=(++rear)%maxsize;
if(rear==front)
{
printf("The Queue is full");
if(!front)
{
rear=maxsize;
}
else
{
rear=rear-1;
}
return false;
}
else
{
q[rear]=item;
return true;
}
}
template<typename T>
bool Queue<T> ::Delete(T &item)
{
if(front==rear)
{
printf("The queue is empty!");
return false;
}
else
{
front=front+1;
front=front%maxsize;
item=q[front];
return true;
}
}
template<typename T>
int Queue<T> ::getsize()
{
return rear-front;
}
1、首先吧,类应该写到.h文件中
2、其次应该写与类名一样的构造函数
Queue()
{
q=new T[maxsize];
rear=front=0;
}
3、template<typename T>
这样的话就可以不限制使用的数据类型了
4、class之后的{}应该加;
5、
bool AddQ(T item);
bool Delete(T &item);
bool QFull();
bool QEmpty();
int getsize();
在类外写这些函数时,每一个函数前应该加template<typename T>
6、还有一个问题:
Delete(T &item)
Add(T item)
为什么一个取地址为什么另一个不取地址
试了一下,好像暂时两个都可以运行
相关文章推荐
- c++ find 函数
- 【C语言】判断字符串是否是回文
- C++ vector 的简单用法
- c++第五次实验--多继承
- more effective C++的读书笔记 ——不要重载&&和||
- 【C语言】动态内存分配alloca
- C++之嵌套类与外围类及友元
- C++中的::操作符
- 关于C++全局变量声明的问题
- c++第五次上机实验——教师干部类
- C++实现双链表
- C++实现双链表
- C++实现双链表
- 基于C语言EOF与getchar()的使用详解
- 第7周 C语言程序设计(新2版) 练习1-13 打印输入单词长度的直方图(水平与垂直)
- 栈的测试--四则运算表达式求值(C语言)
- C++程序设计语言练习5.1
- C语言 文件操作12--文件加密
- C++中的vector容器对象学习笔记
- C++ typedef用法小结