链表5--------删除

代码

cpp 复制代码
void LinkedList::remove(int i) {//删除函数
	if (i<0 || i>size) {//判断输入是否合法
		throw out_of_range("Invalid Position");
	}
	if (i == 0) {//判断删除的是否是头节点
		ListNode* temp = head;//暂存头节点
		head = head->next;//将头节点的后继节点置为新的头节点
		delete temp;//释放原头节点对应的内存
	}
	else {
		ListNode* curr = head;//依旧暂存头节点
		for (int j = 0; j < i - 1; j++) {
			curr = curr->next;
		}
		ListNode* temp = curr->next;//把要删除的元素暂存在temp里面
		curr->next = temp->next;
		delete temp;
	}
	size--;
}

解释

void LinkedList::remove(int i) {//删除函数首先是返回值类型,由于删除不需要返回什么东西,所以是void,然后它要调用类内的成员变量,就加入了作用域,LinkedList:: 然后remove代表删除,参数列表有一个元素是删除元素的索引位。

cpp 复制代码
if(i<0||i>size){
    throw out_of_range("Invalid Position!");
}

函数体内部首先是判断输入是否异常。

cpp 复制代码
if (i == 0) {//判断删除的是否是头节点
		ListNode* temp = head;//暂存头节点
		head = head->next;//将头节点的后继节点置为新的头节点
		delete temp;//释放原头节点对应的内存
	}

首先判断带删除元素是否是第一个元素,然后是,则声明结构体指针暂存头节点(为什么一定要让一个结构体指针指向头节点呢,因为头节点本身作为一个节点,应该包含数据域和指针域两个部分,所以头节点本身就是一个结构体类型的量,里面存放着数据域和指针域),然后把头节点的后继存储的地址赋值给头节点,然后销毁旧头节点的内存空间。

cpp 复制代码
else {
		ListNode* curr = head;//依旧暂存头节点
		for (int j = 0; j < i - 1; j++) {
			curr = curr->next;
		}
		ListNode* temp = curr->next;//把要删除的元素暂存在temp里面
		curr->next = temp->next;
		delete temp;
	}

如果删除元素不是第一个元素,那就先用结构体指针curr暂存头节点,然后利用for循环遍历链表,遍历到curr指向待删除位置的前驱节点,然后声明结构体指针temp暂存待删除结点,然后将curr的后继节点置为temp的后继节点,然后释放temp指向的也就是待删除元素对应的内存空间。

**size--;**最后让链表长度-1。

相关推荐
ai生成式引擎优化技术1 分钟前
拓世网络技术开发工作室的ts概率递推ai工程应用技术GEOChatGPT,不同用户账号信息,网站引用效果
算法
CylMK3 分钟前
题解:UVA1218 完美的服务 Perfect Service
数据结构·c++·算法·深度优先·图论
重生之我是Java开发战士4 分钟前
【广度优先搜索】BFS解决拓扑排序:课程表I,课程表II,火星词典
算法·leetcode·广度优先
墨^O^12 分钟前
并发控制策略与分布式数据重排:锁机制、Redis 分片与 Spark Shuffle 简析
java·开发语言·c++·学习·spark
丶小鱼丶12 分钟前
数据结构和算法之【阻塞队列】上篇
java·数据结构
人道领域13 分钟前
LeetCode【刷题日记】:滑动窗口算法详解:从暴力法到最优解
java·算法·leetcode
凤年徐15 分钟前
封装红黑树实现 mymap 和 myset
网络·c++·算法
zs宝来了21 分钟前
Redis 数据结构底层实现:intset、ziplist、skiplist 深度剖析
数据结构·redis·源码解析·skiplist·ziplist·intset
zhangren0246821 分钟前
Laravel6.x核心特性全解析
开发语言·c++·php
秃头狂魔24 分钟前
【HOT100】DAY1
算法·哈希算法