【数据结构初阶】单链表经典算法题十道(详解+图例)—得道飞升(终篇)
云边有个稻草人 2024-08-25 10:35:05 阅读 72
hi !
目录
9、 环形链表 ||
10、随机链表的复制
终章
9、 环形链表 ||
【图解】
<code>/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
typedef struct ListNode ListNode;
struct ListNode *detectCycle(struct ListNode *head) {
//找相遇节点
ListNode* slow=head;
ListNode* fast=head;
while(fast&&fast->next)
{
slow=slow->next;
fast=fast->next->next;
if(slow==fast)
{
//相遇,开始遍历
ListNode* pcur=head;
while(slow!=pcur)
{
slow=slow->next;
pcur=pcur->next;
}
return slow;
}
}
return NULL;
}
10、随机链表的复制
【图解】
【思路】
1、在原链表的基础上复制新链表
2、置random指针
3、(改变next指针指向)将复制链表和原链表断开
<code>/**
* Definition for a Node.
* struct Node {
* int val;
* struct Node *next;
* struct Node *random;
* };
*/
typedef struct Node Node;
//创建新结点
Node* BuyNode(int x)
{
Node* newnode=(Node*)malloc(sizeof(Node));
newnode->val=x;
newnode->next=newnode->random=NULL;
return newnode;
}
//复制结点
void AddNode(Node* phead)
{
Node* pcur=phead;
while(pcur)
{
Node* Next=pcur->next;
//创建新结点
Node* newnode=BuyNode(pcur->val);
newnode->next=Next;
pcur->next=newnode;
pcur=Next;
}
}
struct Node* copyRandomList(struct Node* head) {
if(head==NULL)
{
return NULL;
}
//第一步:复制结点
AddNode(head);
//第二步:置random
Node* pcur=head;
while(pcur)
{
Node* copy=pcur->next;
if(pcur->random!=NULL)
{
copy->random=pcur->random->next;
}
pcur=copy->next;
}
//第三步:断开链表
pcur=head;
Node* newTail,*newHead;
newTail=newHead=pcur->next;
while(pcur->next->next)
{
pcur=pcur->next->next;
newTail->next=pcur->next;
newTail=newTail->next;
}
return newHead;
}
这十道题做完理解透,想不提升都难
完——
———————————————— 终章 ————————————————
Lemon_米津玄師_高音质在线试听_Lemon歌词|歌曲下载_酷狗音乐酷狗音乐为您提供由米津玄師演唱的高清音质无损Lemonmp3在线听,听Lemon,只来酷狗音乐!
https://t3.kugou.com/song.html?id=cp8Rz2eCPV2
拜拜——
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。