IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C++ linkedlist模板实现 -> 正文阅读

[C++知识库]C++ linkedlist模板实现

C++ linkedlist

#include <iostream>
#include <string>

using namespace std;
template <typename T>   //注意这里没有分号

struct Value
{
	T m_Value;
	Value(){ m_Value=0;}
};

// Value模板具体化(用于处理string类型)
template <>
struct Value <string>
{
	string m_Value;
	Value(){ m_Value.assign("");}
};

// 结点
template <typename T>
struct Node
{
	Node();
	Value<T> m_Value;
	Node<T>* m_Prev;
	Node<T>* m_Next;
};

// 类模板的函数在类外实现,需加上模板参数列表,模板参数
template <typename T>
Node<T>::Node()
{
	m_Prev=nullptr;
	m_Next=nullptr;
}

// 链表
template <typename T>
class LinkedList
{
	private:
		Node<T>* m_Head;
		Node<T>* m_Tail;
		bool m_IsEmpty;
	public:
		LinkedList();
		bool push_back(T val);
		bool push_front(T val);
		bool pop_back();
		bool pop_front();
		bool printList();
};

template <typename T>
LinkedList<T>::LinkedList():
	m_Head(nullptr),
	m_Tail(nullptr),
	m_IsEmpty(true)
	{}

template <typename T>
bool LinkedList<T>::pushback(T val)
{
	Node<T>* node=new Node<T>;
	node->m_Value.m_Value=val;
	if (m_IsEmpty==false)
	{
		m_Tail->m_Next=node;
		node->m_Prev=m_Tail;
		m_Tail=node;
	}
	else
	{
		m_Head = m_Tail = node;
		m_IsEmpty = false;
	}
	return true;
}

template <typename T>
bool LinkedList<T>::pushfront(T val)
{
	Node<T> node=new Node<T>;
	node->m_Value.m_Value=val;
	if (m_IsEmpty==false)
	{
		m_Head->m_Prev = node;
		node->m_Next=m_Head;
		m_Head=node;
	}
	else
	{
		m_Head=m_Tail=node;
		m_IsEmpty = false;
	}
	return true;
}

template <typename T>
bool LinkList<T>::popback()
{
	if (m_IsEmpyt==false)
	{
		Node<T>* delnode = m_Tail;
		m_Tail = m_Tail->m_Prev;

		if(m_Tail==nullptr) 
		{
			m_Head=nullptr;
			m_IsEmpty = true;
		}

		m_Tail->m_Next=nullptr;

		if(delnode)
		{
			delete delNode;
			delNode = nullptr; 
		}
	}
	else
	{
		cout<<"Failed:No element in LinkedList."<<endl;
		return false;
	}
	return true;
}

template <typename T>
bool LinkedList<T> popfront()
{
	if (m_IsEmpty==false)
	{
		Node<T>* delnode=m_Head;
		m_Head=m_Head->m_Next;

		if(m_Head==nullptr)
		{
			m_Tail=nullptr;
			m_IsEmpty=true;
		}

		m_Head->m_Prev = nullptr;
		
		if(delnode)
		{
			delete delnode;
			delnode=nullptr;
		}		
	}
	else
	{
		cout<<"Failed:No element in LinkedList."<<endl;
		return false;
	}
	return true;
}

template <typename T>
bool LinkedList<T>::printList()
{
	Node<T>* node=m_Head;
	while(node)
	{
		cout<<node->m_Value.m_Value<<" ->";
		node=node->m_Next;
	}
	cout<<"nullptr"<<endl;
	return true;
}

void InsertIntData()
{
	LinkedList<int> mylist;
	mylist.push_back(1);
	mylist.push_back(2);
	mylist.push_back(3);
	mylist.printList();
}

void InsertStrData()
{
	LinkedList<string> mylist;
	mylist.push_back('hello');
	mylist.push_back(' ');
	mylist.push_back('world');
	mylist.printList();
}

int main()
{
	InsertIntData();
	InsertStrData();
	return 0;
}	
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-10 14:21:50  更:2021-07-10 14:23:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/4 5:53:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码