考研数据结构-单链表(线性表)

本文探讨了数据结构中的单链表概念,分别讲解了带头结点和不带头结点两种情况,适合考研复习使用。
摘要由CSDN通过智能技术生成

单链表

带头结点

#include <stdio.h>
#include <stdlib.h> //添加malloc函数的头文件
//预定义常量和类型
#define LIST_INIT_SIZE 10 //初始分配量

typedef int ElemType;//取别名 方便改

typedef struct LNode{
   	//定义单链表结点类型
	ElemType data;		//每个结点存放一个数据元素
	struct LNode *next;	//指针指向下一个结点
}LNode,*LinkList;

//初始化一个单链表(带头结点)
bool InitList(LinkList &L){
   
	L=(LNode *)malloc(sizeof(LNode));//分配头结点
	if(L==NULL)//内存不足,分配失败
		return false;
	L->next=NULL;//头结点之后暂时还没有结点
	return true;
}

//正向建立单链表
LinkList List_TailInsert(LinkList &L){
   
	int x;//设ElemType为整型
	L=(LinkList)malloc(sizeof(LNode));//建立头结点
	LNode *s,*r=L;//r为表尾指针
	scanf("%d",&x);//输入结点的值
	while(x!=9999){
   //输入9999表示结束
		s=(LNode *)malloc(sizeof(LNode));
		s->data=x;
		r->next=s;
		r=s;	//r指向新的表尾结点(永远保持r指向最后一个结点)
		scanf("%d",&x);
	}
	r->next=NULL;
	return L;
}
//逆向建立单链表(可以用来逆置)
LinkList List_HeadInsert(LinkList &L){
   
	LNode *s;
	int x;//设ElemType为整型
	L=(LinkList)malloc(sizeof(LNode));//建立头结点
	L->next=NULL;//初始为空链表
	scanf("%d",&x);//输入结点的值
	while(x!=9999){
   //输入9999表示结束
		s=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值