当前位置: 首页 > article >正文

数据结构 ——— 单链表oj题:反转链表

目录

题目要求

手搓一个简易链表

代码实现 


题目要求

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表


手搓一个简易链表

代码演示:

struct ListNode* n1 = (struct ListNode*)malloc(sizeof(struct ListNode));
assert(n1);
struct ListNode* n2 = (struct ListNode*)malloc(sizeof(struct ListNode));
assert(n2);
struct ListNode* n3 = (struct ListNode*)malloc(sizeof(struct ListNode));
assert(n3);
struct ListNode* n4 = (struct ListNode*)malloc(sizeof(struct ListNode));
assert(n4);
struct ListNode* n5 = (struct ListNode*)malloc(sizeof(struct ListNode));
assert(n5);

n1->val = 1;
n2->val = 3;
n3->val = 5;
n4->val = 7;
n5->val = 9;

n1->next = n2;
n2->next = n3;
n3->next = n4;
n4->next = n5;
n5->next = NULL;

代码实现

代码演示:

struct ListNode* reverseList(struct ListNode* head)
{
	if (head == NULL)
		return NULL;

	struct ListNode* prev = NULL;
	struct ListNode* cur = head;
	struct ListNode* next = cur->next;

	while (cur != NULL)
	{
		cur->next = prev;

		// 迭代
		prev = cur;
		cur = next;

		if(next != NULL)
			next = next->next;
	}

	return prev;
}

代码解析:

代码思路:改变节点的指向,将单链表的第一个节点的 next 指向 NULL,第二个节点的 next 指向第一个节点,第三个节点的 next 指向第二个节点…………,以此类推,就完成了链表的反转

代码逻辑:利用一前(prev)一后(next)一中间(cur) 3 个节点指针进行迭代,将 cur 的 next 指向 prev,再依次往后赋值,需要注意的是 next 赋值为下一个节点的时候,要先判断 next 是否为空,再赋值,且结束的条件是中间节点为空,中间节点为空时就表示链表反转到位,最后再返回 prev 节点指针,就是新的头节点指针

代码验证:

代码的时间复杂度和空间复杂度:

while 循环执行了 N 次,每次内部是常数次,且没有开辟额外的空间,得出:

算法的时间复杂度(大O渐进表示法):O(N)

算法的空间复杂度(大O渐进表示法):O(1)


http://www.kler.cn/news/335884.html

相关文章:

  • 滚雪球学Oracle[2.4讲]:创建Oracle数据库实例
  • Maven(6)如何使用Maven进行项目构建?
  • 图解网络OSI模型与TCP/IP
  • Maven 和 NetBeans:集成与使用
  • PCA降维算法
  • cisco交换机命令大全
  • 如何在 Axios 中封装事件中心EventEmitter
  • 0基础跟德姆(dom)一起学AI 机器学习03-线性回归
  • FredNormer: 非平稳时间序列预测的频域正则化方法
  • 双指针——删除有序数组中的重复项
  • 通信工程学习:什么是ICP网络内容服务商
  • [C++]使用onnxruntime部署yolov11-cls图像分类onnx模型
  • CSS基础-盒子模型(三)
  • 远程调用的问题以及eureka原理
  • JAVA学习-练习试用Java实现“回文数”
  • 高性能、编译器编写语言、编程语言的高低贵贱
  • c#里氏替换
  • Leetcode: 0041-0050题速览
  • 数据结构:基本概念及术语
  • 【代码随想录Day30】贪心算法Part04