【数据结构】反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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已经是野指针了。就这样一直遍历到原来指针到最后一个节点为止。

最后返回新节点的头节点。
对了当原链表为空的时候直接返回空指针就可以了。

相关推荐

  1. 数据结构习题--

    2024-04-29 21:04:03       17 阅读
  2. 数据结构 ->

    2024-04-29 21:04:03       9 阅读
  3. 2024-04-29 21:04:03       28 阅读
  4. leetcode-

    2024-04-29 21:04:03       34 阅读
  5. 1

    2024-04-29 21:04:03       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-29 21:04:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-29 21:04:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-29 21:04:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-29 21:04:03       18 阅读

热门阅读

  1. python中json.dumps将中文变成unicode字符的解决办法

    2024-04-29 21:04:03       13 阅读
  2. Spring Boot应用部署 - War包部署

    2024-04-29 21:04:03       11 阅读
  3. 第30篇 RPC概述

    2024-04-29 21:04:03       12 阅读
  4. 题解:CF1946D(Birthday Gift)

    2024-04-29 21:04:03       10 阅读
  5. python第三方库

    2024-04-29 21:04:03       12 阅读
  6. CF1709B - Also Try Minecraft 题解

    2024-04-29 21:04:03       14 阅读
  7. jquery html(““)造成内存上涨

    2024-04-29 21:04:03       10 阅读
  8. SQL注入问题

    2024-04-29 21:04:03       8 阅读