利用C++模板封装链表

2023-05-16

利用C++实现链表模板类

#include <iostream>
#include <stdlib.h>

using namespace std;

template <typename T>
class Node//定义结点类
{
public:
	Node(T data):data(data)
	{
		next = NULL;
	}

	T data;
	Node* next;
};

template <typename T>
class List //定义链表类
{
	Node<T>* head;
	Node<T>* tail;
public:
	List(void)//构造函数
	{
		head = NULL;
		tail = NULL;
	}

	bool empty(void)//判断链表是否为空
	{
		return NULL == head;
	}

	size_t size(void)//获取链表长度
	{
		size_t n = 0;
		for(Node<T>* node=head;node;node=node->next)
		{
			n++;
		}
		return n;
	}

	bool head_del_list(void)//头删除
	{
		if(empty()) return false;
		Node<T>* temp = head;
		head = head->next;
		delete temp;
		return true;
	}
	
	bool tail_del_list(void)//尾删除
	{
		if(empty()) return false;
		
		if(1 == size())
		{
			Node<T>* temp = head;
			delete temp;
			head = NULL;
			tail = NULL;
			return true;
		}
		Node<T>* node=head;
		for(;node->next->next!=NULL;node=node->next);
		node->next = NULL;
		tail = node;
		delete node->next;
		return true;
	}

	bool delete_index_list(int index)//指定位置下标删除
	{
		if(0 > index||index >=size()) return false;
		if(0 == index)
		{
			return head_del_list();
		}
		if(size()-1 == index)
		{
			return tail_del_list();
		}
		Node<T>* node = head;
		for(int i=0;i<index-1;i++)
		{
			node = node->next;
		}
		Node<T>* temp = node->next;
		node->next = node->next->next;
		delete temp;
		return true;
	}

	bool delete_val_list(const T& val)//按值删除
	{
		if(empty()) return false;
		if(head->data == val) return head_del_list();
		if(tail->data == val) return tail_del_list();
		Node<T>* node = NULL;
		for(node=head;NULL!=node;node=node->next)
		{
			if(node->next->data == val)
			{
				Node<T>* temp = node->next;
				node->next = node->next->next;
				delete temp;
				return true;
			}
		}
		return false;
	}

	void head_add_list(const T& data)//头添加
	{
		Node<T>* node = new Node<T>(data);
		if(empty())
		{
			head = node;
			tail = node;
			return ;
		}
		if(head == tail)
		{
			head = node;
			node->next = tail;
			return ;
		}
		node->next = head;
		head = node;
	}

	void tail_add_list(const T& data)//尾添加
	{
		Node<T>* temp = new Node<T>(data);
		if(empty())
		{
			head = temp;
			tail = temp;
			return;
		}
		
		tail->next = temp;
		tail = temp;
	}

	bool insert_list(int index,const T& data)//指定位置添加
	{
		if(0 > index||index >=size()) return false;
		if(0 == index)
		{
			head_add_list(data);
			return true;
		}
		Node<T>* temp = new Node<T>(data);
		Node<T>* node = head;
		for(int i=0;i<index-1;i++)
		{
			node = node->next;
		}
		temp->next = node->next;
		node->next = temp;
		return true;
	}


	void sort_list(void)//排序
	{
		for(Node<T>* node1=head;NULL!=node1->next;node1=node1->next)
		{
			for(Node<T>* node2=node1->next;NULL!=node2;node2=node2->next)
			{
				if(node1->data > node2->data)
				{
					T temp = node1->data;
					node1->data = node2->data;
					node2->data = temp;
				}
			}
		}

	}

	void show_list(void)//遍历
	{
		for(Node<T>* node=head;node;node=node->next)
		{
			cout << node->data << ' ';
		}
		cout << endl;
	}
};

int main()
{
	List<int> s;
	for(int i=0;i<10;i++)
	{
		s.tail_add_list(i);
		//s.tail_add_list(rand()%100);
	}
	cout << "尾添加后:";
	s.show_list();
	s.insert_list(5,186);
	cout << "在下标为5的位置插入数字186后:";
	s.show_list();
	cout << endl;
	s.sort_list();
	cout << "按从小到大排序后:";
	s.show_list();
	cout << endl;
	s.delete_index_list(3);
	cout << "删除原来下标为3的位置数字后:";
	s.show_list();
	cout << endl;
	s.delete_val_list(7);
	cout << "删除值为7的值后:";
	s.show_list();	
}


以下为程序执行后的结果:

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

利用C++模板封装链表 的相关文章

  • 正则表达式(转载)

    正则表达式的基本语法 开始和结尾位置声明 表示字符串的开始 xff0c 要匹配 本身需要使用 例如 xff1a Yao 表示字符串以 Yao 开头 表示字符串的结尾 xff0c 要匹配 本身需要使用 例如 xff1a Yao 表示字符串以
  • apache2网站设置

    apache2网站设置 我们访问一个网址是先解析成对应的IP的80端口开始的 打开apache2网站配置文件 nano etc apache2 sites available 000 default conf 可以看到 lt Virtual
  • apache用户名和密码验证

    apache用户名和密码验证 之前建立的www soft com这个网站我们给他加个访问验证 修改 etc apache2 apache2 conf nano etc apache2 apache2 conf 把 lt Directory
  • php安装swoole插件

    swoole插件 安装wget apt install wget 安装openssl apt install openssl xff08 https要用到 安装phpize apt install php7 3 dev 安装make apt
  • 五:debian安装,附加审批系统

    如果你还没读第一篇和第二篇请阅读第一篇Debian 安装和第二篇Debian 服务器安装 服务器开始安装审批系统 wget c https jiaozhiguan 1258621244 cos ap guangzhou myqcloud c
  • SpringBoot项目的出现java.io.FileNotFoundException: (系统找不到指定的路径。)

    项目场景 xff1a SpringBoot项目的出现java io FileNotFoundException 系统找不到指定的路径 项目场景 xff1a Springboot用到文件上传下载功能 问题描述 xff1a 问题 xff1a j
  • mysql创建用户报错[Err] 1396 - Operation CREATE USER failed for ‘用户名‘@‘%‘的解决方法

    项目场景 xff1a 执行mysql创建用户语句CREATE USER test IDENTIFIED BY 用户名 问题描述 xff1a 执行mysql创建用户语句CREATE USER test IDENTIFIED BY 39 用户名
  • 解决nginx提示:(code=exited, status=203/EXEC)的错误

    项目场景 xff1a 在centos7上启动nginx1 19 安装过程省略 问题描述 xff1a 编译安装一切顺利 xff0c 使用systemctl start nginx时提示如下内容 xff1a span class token p
  • You don‘t have permission to access this resource.

    项目场景 xff1a 访问自己的搭建的网站时apache报错You don t have permission to access this resource 原因分析 遇到如标题那个问题 xff0c 无法进行远程HTTP请求 解决方案 x
  • cmd下windows批处理bat,获取当前系统时间,生成日志文件名

    提示 xff1a 文章写完后 xff0c 目录可以自动生成 xff0c 如何生成可参考右边的帮助文档 目录 Window系统一 范例二 方法详解1 获取日期2 获取时间3 详解 总结更多 关于Linux的写法 Window系统 常用的Win
  • Centos 7 SSH服务安全加固

    描述 禁止SSH空密码用户登录 xff0c 限制可登录用户及来源地址 加固建议 编辑文件 etc ssh sshd config xff0c 将一应配置修改 具体操作命令和步骤 1 编辑文件 etc ssh sshd config vim
  • 第18章 异常处理

    问题 xff1a c 43 43 异常处理是不是必须有try xff0c 才能有catch 下面自己验证下 方法1 xff1a 如果没有try catch语句块能不能处理异常 xff1f include lt string gt inclu
  • Centos7十五项安全加固标准配置(结合等保3)

    写在前面 xff1a 由于所有操作均涉及系统文件 xff0c 建议所有操作前备份文件及做好相关记录 一 检查系统空密码账户 身份鉴别 描述 检查是否存在空口令和root权限的账号 加固建议 对无口令并且可登录的账户 xff0c 进行密码设置
  • ThinkPHP下 自定义日志输出

    项目场景 xff1a 不想调用TP的 think Log类工具 xff0c 而是自定义日志的输出路径 文件名和内容 xff1a 解决方案 xff1a 提示 xff1a 这里填写该问题的具体解决方案 xff1a 1 首先在common php
  • Ubuntu下代理设置方法

    Ubuntu下代理设置方法 一 临时的手段 在命令行中临时设置 xff0c export http proxy 61 34 http username password 64 proxyIP proxyPort 34 xff0c 和其他临时
  • 缓解pandas中DataFrame占用内存过大的问题

    本文最后修改于2018 01 21 xff0c 文章有问题或者转载请及时联系本人 xff0c 如果对你有帮助 xff0c 别忘了点下关注 0 背景 在我们使用pandas进行数据处理的时候 xff0c 有时候发现文件在本地明明不大 xff0
  • “智医助理”噱头>实用性?详解科大讯飞医疗新布局

    关注52AI xff0c 做AI的行业领先者 QQ人工智能行业交流群 xff1a 626784247 01 以456分通过执医考试的 智医助理 xff0c 真的能够用于临床辅助诊断吗 xff1f 在国际权威的肺结节检测大赛LUNA16中刷新
  • centos8上实现私有CA和证书申请颁发

    一 创建生成密钥文件 1 用下面这条命令查看这个路径下有没有文件 如果报错没有 span class token function ls span etc pki CA 2 就递归创建出以下文件 span class token funct
  • Linux下wifi工具wpa_cli使用

    wpa cli使用 扫描查看扫描结果添加network设置SSID选择某个network查看networks使能某个network查询连接情况自动分配IP地址API Demo 扫描 root 64 demo wpa cli i wlan0

随机推荐