温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用C++怎么删除链表的中间节点

发布时间:2021-03-09 17:29:36 来源:亿速云 阅读:171 作者:Leah 栏目:编程语言

使用C++怎么删除链表的中间节点?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

链表结构定义:

typedef struct Node {   int data;   struct Node* next; }node, *pLinkedList;

算法C++代码:

Node* removeMidNode(pLinkedList head) {   if (head->next == NULL || head == NULL)     return head;   if (head->next->next == NULL)     return head->next;   pLinkedList fast = head;   pLinkedList slow = head;   pLinkedList pre = NULL;   /*   head  1    2    3    4    5   pre   slow  fast   */   //1个节点   if (head->next->next == NULL)     return head->next;   while (fast->next != NULL && fast->next->next != NULL)   {     pre = slow;     fast = fast->next->next;     slow = slow->next;   }   //此时fast已到终点,slow为中间节点,pre为中间节点前一个节点   pre->next = slow->next;   free(slow);   slow = NULL;   return head; }

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI