(链表6-16)求链表的倒数第m个元素--C语言

请设计时间和空间上都尽可能高效的算法,在不改变链表的前提下,求链式存储的线性表的倒数第m(>0)个元素。

函数接口定义:

ElementType Find( List L, int m );

其中List结构定义如下:

typedef struct Node PtrToNode;
struct Node {
ElementType Data; /
存储结点数据 /
PtrToNode Next; /
指向下一个结点的指针 /
};
typedef PtrToNode List; /
定义单链表类型 */

L是给定的带头结点的单链表;函数Find要将L的倒数第m个元素返回,并不改变原链表。如果这样的元素不存在,则返回一个错误标志ERROR。

裁判测试程序样例:

#include <stdio.h>
#include <stdlib.h>

#define ERROR -1

typedef int ElementType;
typedef struct Node *PtrToNode;
struct Node {
    ElementType Data;
    PtrToNode   Next;
};
typedef PtrToNode List;

List Read(); /* 细节在此不表 */
void Print( List L ); /* 细节在此不表 */

ElementType Find( List L, int m );

int main()
{
    List L;
    int m;
    L = Read();
    scanf("%d", &m);
    printf("%d\n", Find(L,m));
    Print(L);
    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

5
1 2 4 5 6
3

输出样例:

4
1 2 4 5 6 

分析:

利用差值计算。

注意:

代码:

ElementType Find( List L, int m )
{
    List p=L->Next;
    List q=L->Next;
    int n=0;//统计链表结点总个数
    while(p!=NULL)
    {
        n++;
        if(n>m)
            q=q->Next;
        p=p->Next;
    }
    if(m>n) return ERROR;
    else return q->Data;
}
### C语言实现获取链表倒数第m个元素 为了高效地找到单向链表中的倒数第`m`个节点,可以采用快慢指针的方法。这种方法只需要一次遍历就能完成操作。 #### 使用快慢指针寻找倒数第m个节点 通过创建两个指向头结点的指针——快速指针(`fast`)和慢速指针(`slow`),先让快速指针向前移动`m`步。之后,当快速指针未到达链表末端时,同步前进这两个指针直到快速指针抵达链尾。此时,慢速指针所处位置即为目标节点的位置[^1]。 下面是具体的C语言代码实现: ```c #include <stdio.h> #include <stdlib.h> // 定义链表节点结构体 typedef struct ListNode { int val; struct ListNode *next; } ListNode; /// 创建新节点辅助函数 ListNode* createNode(int value){ ListNode* newNode = (ListNode*)malloc(sizeof(ListNode)); newNode->val = value; newNode->next = NULL; return newNode; } /// 查找链表倒数第m个节点 ListNode* findKthFromEnd(ListNode* head, int m) { if (!head || m <= 0) return NULL; // 参数校验 ListNode *fast = head, *slow = head; for (int i = 0; fast != NULL && i < m - 1; ++i){ // 让fast提前走m-1步 fast = fast->next; } while(fast->next != NULL){ // 同步推进两指针直至fast达到末尾 slow = slow->next; fast = fast->next; } return slow; // 返回slow所在位置作为结果 } ``` 上述程序首先定义了一个简单的链表节点结构以及用于创建新节点的帮助函数。核心逻辑在于`findKthFromEnd()`函数内实现了利用双指针技巧来定位目标节点的过程[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值