单链表的初始化,销毁,置为空表,求表长,判空,按位查找,按值查找,插入,删除,前插建立,后插建立,打印

本文深入探讨了单链表的各种操作,包括如何初始化链表,销毁链表,将其置为空表,计算链表长度,判断是否为空,按位置和值进行查找,以及如何进行插入和删除节点。此外,还介绍了前插和后插建立链表的方法以及打印链表的技巧。对于理解和掌握数据结构中的链表操作具有重要意义。
#include<stdio.h>
#include<stdlib.h>
typedef int ElemType;
typedef struct LNode     //单链表的存储结构定义
{
   
   
	ElemType data;     //数据域
	struct LNode *next;  //指针域
}LNode,*LinkList;                 //*LinkList为LNode类型的指针   LNode *p  ==  LinkList p
enum Status{
   
   ERROR,OK};
LinkList L,r;

Status InitList_L(LinkList &L)   //初始化,构造一个空链表
{
   
   
	L=(LinkList)malloc(sizeof(LNode));
	if(L==NULL)
		return ERROR;
	L->next=NULL;
	return OK;
}

Status DestoryList(LinkList &L)  //销毁链表
{
   
   
 LinkList pre=L; //前驱结点
 LinkList p=L->next;  //当前结点
 while(p!=NULL);
 {
   
   
   free(pre);
   pre=p;
   p=p->next;
 }
 free(pre);  //释放最后一个结点
 printf("销毁成功\n");
 return OK;
}

Status DestoryList_L(LinkList &L)
{
   
   
  LinkList p;
  while (L)
  {
   
   
    p=L;
	L=L->next;
	free(p);
  }
  return OK;
}
Status ClearList(LinkList &L) //将L置为空表
{
   
   
  LinkList p,q;
  p=L->next;
  while(p)
  {
   
   
   q=p->next;
   free(p);
   p=q;
  }
  L->next=NULL;
  return OK;
}

int ListLength(LinkList L)  //求表长,返回元素个数
{
   
   
  LinkList p<
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值