6-4 链式表的按序号查找

本题要求实现一个函数,找到并返回链式表的第K个元素。

函数接口定义:

1
ElementType FindKth( List L, int K );

 其中List结构定义如下:

1
2
3
4
5
6
typedef struct LNode *PtrToLNode;
struct LNode {
    ElementType Data;
    PtrToLNode Next;
};
typedef PtrToLNode List;

 

L是给定单链表,函数FindKth要返回链式表的第K个元素。如果该元素不存在,则返回ERROR

裁判测试程序样例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <stdio.h>
#include <stdlib.h>
 
#define ERROR -1
typedef int ElementType;
typedef struct LNode *PtrToLNode;
struct LNode {
    ElementType Data;
    PtrToLNode Next;
};
typedef PtrToLNode List;
 
List Read(); /* 细节在此不表 */
 
ElementType FindKth( List L, int K );
 
int main()
{
    int N, K;
    ElementType X;
    List L = Read();
    scanf("%d", &N);
    while ( N-- ) {
        scanf("%d", &K);
        X = FindKth(L, K);
        if ( X!= ERROR )
            printf("%d ", X);
        else
            printf("NA ");
    }
    return 0;
}
 
/* 你的代码将被嵌在这里 */

 

代码:

复制代码
ElementType FindKth( List L, int K ){
    if(K<=0){
        return ERROR;
    }
    while(--K){
        L=L->Next;
    }
    if(L!=NULL){
        return L->Data;
    }else{
        return ERROR;
    }
}
复制代码

注意:需要考虑K<=0的情况和查询最后一个元素的情况(极端情况)

posted @   Yohoc  阅读(91)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示