- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
双向链表模板
双向链表模板
//===============================================================
//双向链表
//================================================================
#includeiostream
#includefstream
#includestring
using namespace std;
//-----------------------------------------------------------------
templatetypename T
class DoubleList;
//-----------------------------------------------------------------
templatetypename T
class DoubleNode{
public:
friend class DoubleListT;
DoubleNode(T x);
private:
T data;
DoubleNodeT *right, *left;
};//-------------------------------------------------------------------------
templatetypename T
DoubleNodeT::DoubleNode(T x){
data=x;
right=NULL;
left=NULL;
}//----------------------------------------------------------------------------
templatetypename T
class DoubleList{
public:
DoubleList();
~DoubleList();
void Add(T x);//添加函数
bool IsEmpty()const;//判断是否为空
int Length() const;//返回长度函数
bool Find(int k,T x)const;//查找表中第k个元素是否存在,若存在则把它传到x中
int Search(T x)const;//在表中查找是否data=x的存在,若存在返回其位置
void Delete(int k, T x);//把表中的第k个元素删除链表,并不其值赋给x
void Insert(int k, T x);//在表中第k个位置插入x
void Display()const;//输出函数
void Clear();//清空函数
private:
int length;
DoubleNodeT *first;
DoubleNodeT *last;
};//---------------------------------------------------------------------------
templatetypename T
DoubleListT::DoubleList(){
length=0;
first=NULL;
last=NULL;
}//-----------------------------------------------------------------------------
templatetypename T
void DoubleListT::Insert(int k, T x){
if(k1 || klength+2)
{
cout不存在第k位置,进行元素的插入endl;
return;
}
else
{
length++;
DoubleNodeT *current=new DoubleNodeT(x);
if(k==1)
{
current-right=first;
first-left=current;
current-left=last;
last-right=current;
first=current;
}
else if(k==length) //注意前面length加1了
{
last-right=current;
current-left=last;
current-right=first;
first-left=current;
last=current;
}
else
{
// cout没进来?endl;
Doubl
您可能关注的文档
- 减员增效的神话与现实.doc
- 减肥花茶.doc
- 凌波多媒体网络教室软件.doc
- 凝聚法治力量助推改革攻坚.doc
- 几种制作 Icc 文件的软件的介绍.doc
- 几种烤瓷冠材料性能的比较.doc
- 几种植物的功效.doc
- 凤凰-张家界.doc
- 凤尾竹养殖方法.doc
- 凤梨花的分株养殖.doc
- 医药流通企业仓储信息化建设与供应链协同案例研究.docx
- 2025年脑机接口在智能娱乐互动中的应用前景调研.docx
- 冷链物流电动冷藏车辆调度优化与节能减排分析报告.docx
- 全球数字医疗市场2025年市场规模与增长趋势研究报告.docx
- 探析2025年数据要素市场交易规则中的数据安全难题.docx
- 生鲜零售行业2025年损耗控制与供应链协同创新研究报告.docx
- 冷链物流电动冷藏车辆调度与能源消耗优化方案分析报告.docx
- 现代农业种业创新基地建设项目水资源利用与保护研究报告.docx
- 冷链物流电动冷藏车调度优化方案2025年技术创新与应用.docx
- 冷链物流电动冷藏车调度优化方案2025年政策环境解读.docx
最近下载
- VEICHI伟创 AC310系列变频调速器使用手册2021.06.pdf VIP
- 隧道施工课件.ppt VIP
- 第五届国家级新区经开区高新区班组长管理技能大赛备赛试题库-下(判断题汇总).docx VIP
- DB 6108T 53-2023 煤基固废调理剂修复沙化土地技术规范.docx VIP
- DB6108_T 52-2023 煤基固废调理剂修复盐碱地技术规范.docx VIP
- 行政人事部年终工作总结.pdf VIP
- 行政人事部年终工作总结.pptx VIP
- 第五届国家级新区经开区高新区班组长管理技能大赛备赛试题库-中(多选题汇总).docx VIP
- 化工厂物资明细表.xls VIP
- 第五届国家级新区经开区高新区班组长管理技能大赛试题库(浓缩500题).docx VIP
文档评论(0)