逆转链表的三种方法

方法一:头插法(两个指针)

代码:

复制代码
//逆转带头链表,头插法
LinkList Reverse(LinkList &L){
	LNode *p,*q;//p为工作指针,q为p的后继 
	p=L->next;
	L->next=NULL;
	while(p!=NULL) {//依次摘下节点 
		q=p->next;//暂时存p的后继 
		p->next=L->next;//将p节点插入到头节点之后 
		L->next=p;
		p=q;
	}
	return L;
} 

时间复杂度O(n);空间复杂度O(1)

方法二:三个指针(类似尾插法)

代码:

复制代码
//逆转带头单链表,三指针,类似尾插法 
LinkList Reverse(LinkList &L){
	LNode *p,*q=L->next,*r=q->next;
	 q->next=NULL;//处理第一个节点 
	 while(r!=NULL){//r不为空,说明q面还有节点 
	 	p=q;
	 	q=r;
	 	r=r->next;
	 	q->next=p;//反转指针 
	 }
	 L->next=q;//处理最后一个节点 
	 return L;
}

时间复杂度O(n);空间复杂度O(1)

方法三:利用栈的先进后出

代码:

复制代码
struct ListNode* reverseList(struct ListNode* head){
	if(head==NULL){
		return NULL;
	}
	struct ListNode* p=head;
	int size=0;
	while(p != NULL){//计算链表长度 
		size++;
		p=p->next;
	}
	struct ListNode* stack[size];
	int top=-1;
	p=head;
	while(p != NULL){//进栈 
		stack[++top]=p;
		p=p->next;
	} 
	struct ListNode* head1=stack[top];
	p=head1;
	while(top != -1){//出栈 
		p->next=stack[top--];
		p=p->next;
	}
	p->next=NULL;
	return head1; 
 
}

时间复杂度:O(n);空间复杂度O(n)

相关推荐
历程里程碑1 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
sin_hielo1 小时前
leetcode 1653
数据结构·算法·leetcode
李日灐1 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
熬夜有啥好1 小时前
数据结构——排序与查找
数据结构
YuTaoShao1 小时前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法二)排序 + 二分查找
数据结构·算法·leetcode
wangluoqi1 小时前
26.2.6练习总结
数据结构·算法
Yvonne爱编码1 小时前
链表高频 6 题精讲 | 从入门到熟练掌握链表操作
java·数据结构·链表
铉铉这波能秀2 小时前
LeetCode Hot100 中 enumerate 函数的妙用(2026.2月版)
数据结构·python·算法·leetcode·职场和发展·开发
墨有6662 小时前
哈希表从入门到实现,一篇吃透!
数据结构·算法·哈希算法
啊阿狸不会拉杆2 小时前
《机器学习导论》第 7 章-聚类
数据结构·人工智能·python·算法·机器学习·数据挖掘·聚类