本题要求实现一个函数,求链式表的表长。
函数接口定义:
int Length( List L );
其中List结构定义如下:
typedef struct LNode *PtrToLNode;
struct LNode {
ElementType Data;
PtrToLNode Next;
};
typedef PtrToLNode List;
L是给定单链表,函数Length要返回链式表的长度。
裁判测试程序样例:
#include <stdio.h>
#include <stdlib.h>
typedef int ElementType;
typedef struct LNode *PtrToLNode;
struct LNode {
ElementType Data;
PtrToLNode Next;
};
typedef PtrToLNode List;
List Read(); /* 细节在此不表 */
int Length( List L );
int main()
{
List L = Read();
printf("%d\n", Length(L));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
1 3 4 5 2 -1
输出样例:
5
题目都是给的伪代码,说实话挺恶心的,毕竟没有实在的数来的清楚明了,不过也还是要习惯,这是我第一次做这个上边的题,刚上来还是有点懵逼,不知道让我怎么写,原来只是让我写个函数就可以了。。
思路分析:求链表表长,单链表只需要判断是否为空即可,每有一个符合条件的,就让记录长度的变量增1,循环终止条件即为到达链表表尾,结点为空。PtrToLNode Next表示LNode类型的指针,因为每一个结点都是LNode类型。
int Length(List L)
{
int len = 0;
List list = L;//指向头结点
while (list != NULL)
{
len++;
list = list->Next;
}
return len;
}