数据结构核心代码 day3

博主分享了学习C语言的心得,强调在考研准备阶段直接上机敲伪代码可能会遇到困难。建议先理解书本知识,结合视频教程进行学习。文章介绍了双链表的节点定义及插入、删除操作,并给出了静态链表的结构定义。

注:我在学习C语言的时候,自己会敲一些代码,看到运行成功是特别高兴的,
但是考研书上的其实是伪代码,直接在电脑上是跑不通的,还需要很多加工。
如果只是准备考研初试,建议不要直接上机敲,因为初学者会看到红了一大片,都是bug,很难或者需要花很长时间才能改对。
可以先吸收书上的精华,每天抽空可以再找一些学习视频,听讲解再去写代码,这时候有指导会进步更快。

2.3 双链表
双链表节点定义
typedef struct DNode{ //定义双链表结点类型
ElemType data; //数据域
struct DNode *prior,*next; //前驱和后继指针
}DNode,*DLinkList;

双链表基本操作
插入
s->next=p->next; //将结点s插入到结点p之后
p->next->prior=s;
s->prior=p;
p->next=s;

删除
p->next=q->next; //图2-11中步骤1
q->next->prior=p; //图2-11中步骤2
free(q);

2.4 静态链表
#define MaxSize 50 //静态链表的最大长度
typedef struct{ //静态链表结构类型的定义
ElemType data; //存储数据元素
int next; //下一个元素的数组下标
}SLinkList[MaxSize];

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值