【数据结构】反转链表

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


c 复制代码
Definition for singly-linked list.
  struct ListNode {
      int val;
      struct ListNode *next;
  };
 
typedef struct ListNode ListNode;
struct ListNode* reverseList(struct ListNode* head) {
    if(head == NULL)
    {
        return head;
    }
    ListNode*n1,*n2,*n3;
    n1=NULL;n2=head;n3=n2->next;
    
    while(n2)
    {
        n2->next=n1;
        n1=n2;
        n2=n3;
        if(n3)
            n3=n3->next;
    }
    return n1;

    
}

创建三个临时变量,n1为新链表,n2为原来链表的头节点,n3为原来链表的头节点的下一个节点。

用while循环判断条件为n2不能为空,让n2的next指针连上新链表的头节点。然后让n1=n2,也就是让新链表的头节点为n2。然后让n2=n3,这个节点传完了要从下一个节点了的位置开始传了。到这里要判断n3是否为空指针,因为n3是n2的下一个节点,while循环的判断条件是n2不为空也就是当n2遍历到最后一个节点的时候n3已经是野指针了。就这样一直遍历到原来指针到最后一个节点为止。

最后返回新节点的头节点。

对了当原链表为空的时候直接返回空指针就可以了。

相关推荐
2301_788770551 分钟前
OJ模拟2
数据结构·算法
岑梓铭9 分钟前
《考研408数据结构》第三章3(数组矩阵)复习笔记
数据结构·笔记·矩阵
Fcy64810 分钟前
算法竞赛有关数据结构的补充(3)—— 二叉树、堆和哈希表的静态实现(包括红黑树和AVL树动态实现)
数据结构·算法·散列表
代码探秘者10 分钟前
【算法篇】6.分治
java·数据结构·后端·python·算法·排序算法
岑梓铭29 分钟前
《考研408数据结构》第三章2(栈、队列应用)复习笔记
数据结构·笔记
计算机安禾30 分钟前
【数据结构与算法】第8篇:线性表(四):双向链表与循环链表
c语言·开发语言·数据结构·c++·算法·链表·visual studio
wangchunting30 分钟前
数据结构-线性数据结构
java·开发语言·数据结构
豆豆的java之旅12 小时前
软考中级软件设计师 数据结构详细知识点(含真题+练习题,可直接复习)
java·开发语言·数据结构
北顾笙98012 小时前
day07-数据结构力扣
数据结构
似水এ᭄往昔14 小时前
【数据结构】--链表OJ
数据结构·算法·链表