C语言/数据结构——每日一题(反转链表)

一.前言

大家好!今天又是每日一题环节。今天我为大家分享了一道单链表题——反转链表。

废话不多说,让我们直接进入正题吧。

二.正文

1.1题目信息

这是一道leetCode上面的一道题:https://leetcode.cn/problems/reverse-linked-list

1.2解题思路

我们依旧可以创建一个新单链表的思想,让旧链表中的元素依次头插到我们的新链表中。

我创建了四个指针,分别是ListNode*pcur、ListNode*phead、ListNode* ptail,和ListNode*pnext。

pcur:该指针的创建是为了遍历原单链表,

phead:该指针的创建是为了表示新单链表的头节点,为后面元素插入提供地址。

ptail:该指针的创建是为了表示是新单链表的尾节点。

pnext:该指针的创建是为了保存pcur在遍历中的下一节点的地址,防止pcur在插入到旧链表后pcur后面的节点找不到。

1.3代码实现

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 typedef struct ListNode ListNode;
struct ListNode* reverseList(struct ListNode* head)
{
 ListNode* pcur=head;
 ListNode* phead;
 ListNode* ptail;
 ListNode* pnext;
 phead=ptail=pnext=NULL;
 if(head==NULL)   
 {
    return head;
 }
 else
 {
    while(pcur)
    {
        if(phead==NULL)
        {
            phead=ptail=pcur;
        }
        else{
            pnext=pcur->next;
            pcur->next=phead;
            phead=pcur;
            pcur=pnext;
        }
        if(pcur!=pnext)
        pcur=pcur->next;
    }
    ptail->next=NULL;
    return phead;
 }
}

这是基于LeetCode环境下运行的代码。

需要特殊注意的是:需要让尾节点ptail->next=NULL;否则会报错。

三.结文

咳咳,自我感觉对于这道题,我的解题办法是有一些搓的。欢迎大佬们指正或者给出你们

的见解。那么,今天的题目分享就到此结束,咱们下期再见。

相关推荐

最近更新

  1. TCP协议是安全的吗?

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

    2024-05-03 05:44:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

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

    2024-05-03 05:44:01       18 阅读

热门阅读

  1. Spring 之 MatchingStrategy

    2024-05-03 05:44:01       10 阅读
  2. 应用zabbix的实时导出(real-time export)功能

    2024-05-03 05:44:01       12 阅读
  3. 定时器使用

    2024-05-03 05:44:01       8 阅读
  4. Web开发之上传图片

    2024-05-03 05:44:01       9 阅读
  5. CANopen学习笔记

    2024-05-03 05:44:01       10 阅读
  6. 揭秘靠信息差搞钱的三个步骤!

    2024-05-03 05:44:01       12 阅读
  7. 快速了解Linux IPC

    2024-05-03 05:44:01       12 阅读
  8. 嵌入式-进程、线程

    2024-05-03 05:44:01       10 阅读
  9. PostgresQL-丢失各种数据文件如何恢复

    2024-05-03 05:44:01       11 阅读
  10. AtCoder ABC351 A-D题解

    2024-05-03 05:44:01       10 阅读
  11. 【无标题】

    2024-05-03 05:44:01       11 阅读
  12. Docker网络详解

    2024-05-03 05:44:01       9 阅读