CSAPP lab0 简单链表操作

本文详细介绍了如何完成CSAPP实验中关于单链表的各项操作,包括创建空链表、释放链表、头部插入和删除、尾部插入、获取链表长度以及不使用额外空间翻转链表。实现中关键在于维护一个指向链表尾部的指针,以确保大部分操作能在O(1)时间内完成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.LAB要求

完成单链表的操作,包括
1. 新建空链表
2. 释放列表
3. 头部插入元素
4. 尾部插入元素,O(1)时间
5. 删除头部元素
6. 获取size,O(1)时间
7. 翻转,不允许分配额外的空间,不能使用递归

/*
  Create empty queue.
  Return NULL if could not allocate space.
*/
queue_t *q_new(); 

/*
  Free all storage used by queue.
  No effect if q is NULL
*/
void q_free(queue_t *q);

/*
  Attempt to insert element at head of queue.
  Return true if successful.
  Return false if q is NULL or could not allocate space.
 */
bool q_insert_head(queue_t *q, int v);

/*
  Attempt to insert element at tail of queue.
  Return true if successful.
  Return false if q is NULL or could not allo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值