C++ 模板循环链表练习

abacabcc 2017-11-24 09:58:24
初学C++ 刚看了模板的视频,自己把以前写的一个循环链表改成模板,添加的节点的那个函数死活编不过去,求大神帮看看

#include <iostream>
#include <cstring>//memset
using namespace std;

template<typename T>
struct Node
{
T List_data;
Node *List_pPre;
Node *List_pNext;
};

template<typename T>
Node<T>* NewHead(const T data)
{
Node<T>* listHead = new Node<T>;
memset(listHead,0,sizeof(Node<T>));

listHead->List_data = data;
listHead->List_pNext = listHead;
listHead->List_pPre = listHead;

return listHead;
}

template<typename T>
void AddNod(Node<T>* listHead,const T data)
{
Node<T>* ptemp = listHead;

while(ptemp->List_pNext != listHead)
{
ptemp = ptemp->List_pNext;
}

Node<T>* m_Node = new Node<T>;
memset(m_Node,0,sizeof(Node<T>));

m_Node->List_data = data;
m_Node->List_pNext = listHead;
m_Node->List_pPre = ptemp;
ptemp->List_pNext = m_Node;
listHead->List_pPre = m_Node;

cout << "add data = " << data << " success!" << endl;
}

template<typename T>
void ListDis(const Node<T>* listHead)
{
Node<T>* ptemp = listHead->List_pNext;
int i = 1;

cout << "head" << " = " << listHead->List_data << endl;
while(ptemp!= listHead)
{
cout << "Node" << i << " = " << ptemp->List_data << endl;
ptemp = ptemp->List_pNext;
i++;
}
}

//加入a个节点后最多只能删a个节点,不能删除头节点
template<typename T>
void List_Delete_Node(Node<T>* listHead,T nNode)
{
int m_count = 0;

Node<T>* ptemp = listHead;
while(ptemp->List_pNext != listHead)
{
m_count++;
ptemp = ptemp->List_pNext;
}
if(0 >= nNode || m_count < nNode)
{
cout << "delete error!" << endl;
return;
}

ptemp = listHead;
m_count = nNode;
while(m_count != 0)
{
m_count--;
ptemp = ptemp->List_pNext;
}
ptemp->List_pNext->List_pPre = ptemp->List_pPre;
ptemp->List_pPre->List_pNext = ptemp->List_pNext;
delete ptemp;
cout << "delete Node " << nNode << "success!" << endl;
}
template<typename T>
void List_Delete_All(Node<T>* listHead)
{
Node<T>* ptemp = listHead;

while(ptemp->List_pNext != listHead)
{
ptemp = ptemp->List_pNext;
delete ptemp->List_pPre;
}
delete ptemp;
cout << "delete all list success!" << endl;
}
int main()
{
Node<int>* listHead;

listHead = NewHead(0);
AddNode(listHead,6); //E:\main.cpp:111: error: 'AddNode' was not declared in this scope
AddNode(listHead,a);
AddNode(listHead,9);
AddNode(listHead,10);
AddNode(listHead,11);
AddNode(listHead,12);
cout << "---------------------" << endl;

ListDis(listHead);
cout << "---------------------" << endl;

List_Delete_Node(listHead,2);
ListDis(listHead);
cout << "---------------------" << endl;

List_Delete_Node(listHead,2);
ListDis(listHead);
cout << "---------------------" << endl;
List_Delete_All(listHead);
return 0;
}

...全文
153 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
paschen 版主 2017-11-24
  • 打赏
  • 举报
回复
其次,AddNode(listHead, a);这句里的a你并没有定义,不知是什么
paschen 版主 2017-11-24
  • 打赏
  • 举报
回复
template<typename T> void AddNod(Node<T>* listHead, const T data) 改成: template<typename T> void AddNode(Node<T>* listHead, const T data) 注意函数名的拼写
heronism 2017-11-24
  • 打赏
  • 举报
回复
引用 1 楼 hdt 的回复:
你申明的是 AddNod
高手,正解
真相重于对错 2017-11-24
  • 打赏
  • 举报
回复
你申明的是 AddNod

64,691

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧