反转链表 (oj题)

一、题目链接

https://leetcode.cn/problems/reverse-linked-list/submissions/538124207

二、题目思路

1.定义三个指针,p1先指向NULL p2指向头结点 p3指向第二个结点

2.p2的next指向p1。然后移动指针,p1来到p2的位置,p2来到p3的位置,p3去到它的下一个结点

循环执行,直至p2到达空结点的位置 。这时,反转结束,新头结点就是p1现在的位置

三、题解代码

cpp 复制代码
struct ListNode* reverseList(struct ListNode* head) 
{
    if(head==NULL)//如果是空链表直接返回NULL
    return NULL;

  struct ListNode*p1=NULL;//p1先指向NULL
 struct ListNode* p2 = head;//p2指向头结点

 struct ListNode* p3 = p2->next;//p3指向第二个结点

//p2的next指向p1。然后移动指针,p1来到p2的位置,p2来到p3的位置,p3去到它的下一个结点
//循环执行,直至p2到达空结点的位置。这时,反转结束,新头结点就是p1现在的位置
while (p2!= NULL)
{
    p2->next = p1;
    p1 = p2;
    p2 = p3;
    
    //如果p3不为NULL,才能让它移动到下一个位置
    if(p3!=NULL)
    p3 =p3->next;
}

//反转结束,新头结点就是p1现在的位置
head = p1;
return head;
 }
相关推荐
星迹701 分钟前
C语言相关的数电知识
c语言·开发语言
hakesashou2 分钟前
python 如何使数组中的元素不重复
开发语言·python
2501_944424122 分钟前
Flutter for OpenHarmony游戏集合App实战之消消乐下落填充
android·开发语言·flutter·游戏·harmonyos
Filotimo_3 分钟前
JWT的概念
java·开发语言·python
黎雁·泠崖6 分钟前
Java字符串系列总结篇|核心知识点速记手册
java·开发语言
永远都不秃头的程序员(互关)15 分钟前
【K-Means深度探索(十二)】K-Means项目实战:从数据到决策的完整工作流!
算法·机器学习·kmeans
散峰而望16 分钟前
【基础算法】高精度运算深度解析与优化
数据结构·c++·算法·链表·贪心算法·推荐算法
半条-咸鱼24 分钟前
C语言基础语法+STM32实践学习笔记 | 指针/寄存器核心应用
c语言·stm32·学习·嵌入式
彩妙不是菜喵29 分钟前
STL精讲:string类
开发语言·c++
彭泽布衣30 分钟前
gdb调试方法总结
linux·c语言·gdb·故障排查·段错误