C++ 模板 栈和队列的数据结构
本帖最后由 鸦领主 于 2021-1-31 20:31 编辑1、C++模板技术也叫泛型技术:
泛型就是使用的类型是各种类型,运算过程相同。
在模板技术出现之前,主要使用define和重载函数实现泛型。
2、函数模板定义:
template <class 模板变量>
template <typename 模板变量>//俩个都是一样定义哪一个都行
返回值函数(模板变量...)
3、模板函数的调用:
a)标准调用:
函数名<模板类型>(参数列表);
根据指定模板类型生成对应的函数。
b)非标准调用:根据参数类型自动识别生成一个新的类型的函数。
函数名(参数列表);
2.俩个小的数据结构
栈的数据结构
栈是线性结构,特点是先进后出
输入12345.输出就是54321
#pragma once
template<typename DATA>//模板
class CStack
{
DATA *m_pdata;
int nTop;
int m_Count;
public:
CStack(int count=5)//缺省是5
{
m_pdata = new DATA;
nTop = 0;
m_Count = count;
}
~CStack()
{
delete[]m_pdata;
}
bool isFull()//判断栈是否满了
{
return nTop >= m_Count;
}
void push(const DATA& data)//入栈
{
if (!isFull())
m_pdata = data;
}
bool isEmpty()//判断栈是否空了
{
return nTop == 0;
}
bool pop(DATA& data)//出栈
{
if (isEmpty())
return false;
data = m_pdata[--nTop];
return true;
}
};<div>
</div><div>队列的数据结构</div><div>队列是线性结构,先进先出环形结构,需要多余出来一个位置
template<typename DATA>//模板
class Queue //队列
{
DATA* m_pdata;
int m_nHead, m_nTail;
int m_Count;
public:
Queue(int count = 5)
{
m_pdata = new DATA;
m_nHead = m_nTail = 0;
m_Count = count + 1;//加1是多余出来一个位置
}
bool isFull()//判断是否满了//②再次进入判断此时Tail是0+1,Count是6,余数是1,1==2不符合可以进入if ,③此时Tail是1+1,Count是6,余数是2,2==2不能进入if 而m_nTail将会变成新的空位
{ //①当你要输入5次的话,因为下面有一个count+1那么就是6,那么m_nTail会加加5次,将5个内容一次送入目的也达到了,
return (m_nTail + 1)%m_Count == m_nHead; //①此时m_nTail是5+1(加1是不让多出的位置用掉) 余6,余数是0和m_Head相等,就不再会进入if里面了
} //②如果用pop取出俩个数字,那么m_nHead会加俩次变成2, 0==2的就不会成立,将再次进入if
void push(const DATA& data)//入栈
{
if (!isFull())
{//②取出来的数字将会赋值到多余的位置上也就是m_pdata上面
m_pdata = data;//将内容赋值给m_pdata,m_pdata...m_pdata②data将会赋值给m_pdata
m_nTail = ++m_nTail % m_Count;//②这一步6%6余数0赋值给m_Taill ③Tail加加会变成1
}
}
bool isEmpty()//判断是否空了
{
return m_nHead == m_nTail;
}
bool pop(DATA& data)//出栈
{
if (isEmpty())//第一次进入m_nHead(2)==m_nTail(1)不成立不进入第四次进入m_nHead(5)==m_nTail(1)不成立不进入 第六次进入m_nHead(5)==m_nTail(1) 最后一次1==1不再进入if
return false;
data = m_pdata;//第一次将m_pdatap内容赋值给data 第五次m_pdatap内容赋值给data 第六次m_pdatap内容赋值给data
m_nHead = ++m_nHead % m_Count;//第一次++m_nHead(3)%m_Count(6)余数为3赋值给m_nHead 第五次++m_nHead(6)%m_Count(6)余数为0赋值给m_nHead 第六次++m_nHead(1)%m_Count(6)余数为1赋值给m_nHead
return true;
}
};</div>
页:
[1]