当前位置:   article > 正文

【数据结构与算法】---OJ手撕链表题_struct listnode 序列化

struct listnode 序列化

作者:旧梦拾遗186

专栏:数据结构成长日记

目录

链表的中间结点

题解

链表中倒数第k个结点 

描述

题解

 链表的分割

描述

题解


链表的中间结点

链表的中间结点https://leetcode.cn/problems/middle-of-the-linked-list/

给定一个头结点为 head 的非空单链表,返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

示例 1:

输入:[1,2,3,4,5]
输出:此列表中的结点 3 (序列化形式:[3,4,5])
返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。
注意,我们返回了一个 ListNode 类型的对象 ans,这样:
ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.
示例 2:

输入:[1,2,3,4,5,6]
输出:此列表中的结点 4 (序列化形式:[4,5,6])
由于该列表有两个中间结点,值分别为 3 和 4,我们返回第二个结点。
 

提示:

给定链表的结点数介于 1 和 100 之间。

题解

思路:可以遍历一遍求出长度在除以2。不过我们采用另一种做法只遍历链表一遍即可,采用快慢指针即可。慢指针一次走一步,快指针一次走两步,我们要区分是奇数个结点还是偶数个结点。

对于奇数个:fast到尾,而slow刚好到中间结点

对于偶数个:fast走到空,而slow刚好走到中间结点。

  1. struct ListNode* middleNode(struct ListNode* head){
  2. struct ListNode* fast=head;
  3. struct ListNode* slow=head;
  4. while(fast!=NULL&&fast->next!=NULL)
  5. {
  6. slow=slow->next;
  7. fast=fast->next->next;
  8. }
  9. return slow;
  10. }

链表中倒数第k个结点 

链表中倒数第k个结点https://www.nowcoder.com/practice/529d3ae5a407492994ad2a246518148a?tpId=13&&tqId=11167&rp=2&ru=/activity/oj&qru=/ta/coding-interviews/question-ranking

描述

输入一个链表,输出该链表中倒数第k个结点。

示例1

输入:

1,{1,2,3,4,5}

返回值:

{5}

题解

  1. struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {
  2. struct ListNode* fast=pListHead;
  3. struct ListNode* slow=pListHead;
  4. int i=0;
  5. for(i=0;i<k;i++)
  6. {
  7. if(fast==NULL)
  8. return NULL;
  9. fast=fast->next;
  10. }
  11. while(fast)
  12. {
  13. fast=fast->next;
  14. slow=slow->next;
  15. }
  16. return slow;
  17. }
  1. class Solution {
  2. public:
  3. ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
  4. struct ListNode* slow = pListHead;
  5. struct ListNode* fast = slow;
  6. while(k--)
  7. {
  8. if(fast)
  9. fast = fast->next;
  10. else
  11. return NULL;
  12. }
  13. while(fast)
  14. {
  15. slow = slow->next;
  16. fast = fast->next;
  17. }
  18. return slow;
  19. }
  20. };

 链表的分割

 链表分割https://www.nowcoder.com/practice/0e27e0b064de4eacac178676ef9c9d70?tpId=8&&tqId=11004&rp=2&ru=/activity/oj&qru=/ta/cracking-the-coding-interview/question-ranking

描述

现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。

题解

思路:我们给出两个带头结点的新链表,值小于X的放在第一条链表,值大于X的放在第二条链表,最后两个新链表连接起来即可。同时,我们需要注意到如果链表为空的时候,我们可以画个图:

 

  1. public:
  2. ListNode* partition(ListNode* pHead, int x) {
  3. // write code here
  4. ListNode*lessguard = (ListNode*)malloc(sizeof(ListNode));
  5. lessguard->next = NULL;
  6. ListNode*lesstail = lessguard;
  7. ListNode*greaterguard = (ListNode*)malloc(sizeof(ListNode));
  8. greaterguard->next =NULL;
  9. ListNode*greatertail = greaterguard;
  10. ListNode*cur = pHead;
  11. while(cur)
  12. {
  13. if(cur->val<x)
  14. {
  15. lesstail->next = cur;
  16. lesstail = lesstail->next;
  17. }
  18. else
  19. {
  20. greatertail->next = cur;
  21. greatertail = greatertail->next;
  22. }
  23. cur = cur->next;
  24. }
  25. lesstail->next = greaterguard->next;
  26. greatertail->next = NULL;
  27. pHead = lessguard->next;
  28. free(lessguard);
  29. free(greaterguard);
  30. return pHead;
  31. }
  32. };

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/661772
推荐阅读
相关标签
  

闽ICP备14008679号