设计一个算法,找到链表的倒数第m个元素,假设最后一个元素为倒数第0个。算法的复杂度为n。
方法一:遍历链表,得到链表的长度,再找到链表的第n-m个元素即可(如果链表的长度知道就直接找第n-m个元素)。
方法二:双指针查找。用两个指针p1、p2,开始都指向头节点。p1先移动,当p1和p2的距离为m时,两个指针一起移动,当p1移动到尾节点时,此时p2指向的节点就是要找的节点。
具体代码:
#include <stdio.h>
#include <stdlib.h>
typedef struct Node
{
int data;
Node* pNext;
}*pNode;
pNode InitNode()
{
pNode pHead=(pNode)malloc(sizeof(Node));
pHead->pNext=NULL;
return pHead;
}
void CreateListNode(pNode pHead,int nodeNum)
{
pNode pTail=pHead;
for (int i=0;i<nodeNum;i++)
{
pNode pCur=(pNode)malloc(sizeof(Node));
pCur->data=i+1;
pTail->pNext=pCur;
pCur->pNext=NULL;
pTail=pCur;
}
}
void ShowNodeData(pNode pHead)
{
while(pHead->pNext)
{
printf("%d\n",pHead->pNext->data);
pHead=

设计一个复杂度为O(n)的算法,解决找到链表中倒数第m个元素的问题。可以采用两种方法:1) 先获取链表长度,然后找到第n-m个元素;2) 使用双指针p1和p2,p1先行移动m步,之后两者同步移动,当p1到达尾部,p2即为所求节点。
最低0.47元/天 解锁文章
359

被折叠的 条评论
为什么被折叠?



