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

逆转链表的三种方法

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

代码:

//逆转带头链表,头插法
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)


http://www.kler.cn/a/300753.html

相关文章:

  • SQL ON与WHERE区别
  • python——句柄
  • HTML中如何保留字符串的空白符和换行符号的效果
  • python爬虫爬取淘宝商品比价||淘宝商品详情API接口
  • Maven 配置本地仓库
  • SQL BETWEEN 操作符
  • 从C语言过渡到C++
  • 基于SpringBoot+Vue的学生选课系统
  • 贷款电话“轰炸式“营销背后:银行生存战与我们的“贷“价生活
  • RP2040 C SDK RTC功能使用
  • 6个免费icon图标素材网站
  • Spring Cloud之三 网关 Gateway
  • flink写入hudi MOR表
  • vue 使用jszip,file-saver下载压缩包,自定义文件夹名,文件名打包下载为zip压缩包文件,全局封装公共方法使用。
  • webctf
  • XML 保存 显示XML 方式 encoding=“UTF8“
  • OpenHarmony鸿蒙( Beta5.0)智能窗户通风设备开发详解
  • 笔记:Centos Jdk Nginx 安装包安装命令
  • 【Django】Django REST Framework接口实现详解:从APIView到ModelViewSet
  • 在 PyTorch 中,除了 pad_sequence 还有哪些其他处理序列数据的函数?时间序列数据 预处理
  • [项目][WebServer][TcpServer]详细讲解
  • [计算机网络]-计网学习笔记-计网知识点总结(附完整笔记)
  • C++自学笔记35(文件操作)
  • 抖音视频素材哪里来的?抖音视频素材库在哪里找分享
  • Vue 常用语法
  • 【springboot】简易模块化开发项目整合MyBatis-plus