数据结构与算法-C语言实现单链表,以及单链表的常用方法

这篇博客介绍了如何在C语言中实现单链表,包括Struct的使用和定义,以及通过指针操作链表成员的方法。示例代码展示了具体的实现细节。
摘要由CSDN通过智能技术生成

C语言知识点提要:

Struct:Struct 内可放置各种类型的数据

格式为:

Struct TagName {

.............(元素类型 元素名称)

}

不同Struct内的成员名称可以相同

也可使用以下方法来定义Struct

struct {......}  x,y,z;

上面定义的TagName可用于之后再定义,例如:

struct TagName tg;

可使用struct-mame.member来打印值。

若定义了一个struct类型的指针变量,则可使用“->"符号来访问变量

例如:

struct TagName *p;

p->member-of-structure

 

具体代码如下:

struct Node;

typedef struct Node *PtrToNode;

typedef PtrToNode List;

typedef PtrToNode Position;

int IsEmpty(List L);

int IsLast(Position P , List L);

Position Find(int X,List L);

List MakeEmpty(List L);

void Delete(int X,List L);

Position FindPrevious(int X,List L);

void Insert(int X,List L,Position P);

void DeleteList(List L);

struct Node

{

    int Element;

    Position Next;

};



/*

删除现有链表

并释放列表元素占用空间

*/

VOid DeleteList(List L){

    Position P,TmpCell;

    P=L->Next;

    L->Next=NULL;

    while(P!=NULL){

        TmpCell=P->Next;

        free(P);

        P=TmpCell;

    }

}



/*

插入元素到链表的指定位置

*/

void Insert(int X,List L,Position P){

    TmpCell=malloc(sizeof(struct Node))

    TmpCell->Element=X;

    TmpCell->Next=P->Next;

    free(P->Next)

    P->Next=TmpCell;



    return P;



}





/*

定位到当前元素的前一个元素

*/

void FindPrevious(int X,List L){

    Position P;

    P=L->Next;



    while(P->Next!=NULL && P->Next->Element!=X){

        P=P->Next;

    }



    return P;

}

/*

删除当前链表中的某个元素

*/

void Delete(int X,List L){


    Position P;

    P=L->Next;

    while(P->Next!=NULL && P->Element!=X)

        P=P->Next;

    TmpCell=P->Next;

    P->Next=TmpCell->Next;

    free(TmpCell);

}


/*

清空当前的链表

*/
List MakeEmpty(List L){



    Position P;

    P=malloc(sizeof(struct Node))

    if(P==NULL){

        printf("%s","error")

    }

    P->Element=NULL;

    P->Next=NULL;

    return P;

}


/*

定位到单链表中的某个值的位置

*/

Position Find(int X,List L){

    Position P;

    P=L->Next;

    while(P->Next != NULL && P->Element!=X){

        P=P->Next;

    }

    return P;

}


/*

判断单链表是否为空

*/

int IsEmpty(List L){

    return L->Next==NULL;

}


/*

判断当前位置是否最后一个元素

*/

int IsLast(Position P,List L){

    return P->Next==NULL;

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值