C语言链表

很多时候需要用到C语言方式的内置链表,根据处理类型多重交叉链接, 非常方便, 这里贴一下链表实现。


// 内置链表
#ifndef CoreLink_h__
#define CoreLink_h__

// 链表
struct LinkNode
{
	LinkNode* next;
	LinkNode* front;
};

// 初始化链表
#define InitLink(root) ((root)->next = (root)->front = (root))

// 添加到结尾
#define LinkAddToTail(root, node)	\
{									\
	(node)->next = (root);			\
	(node)->front = (root)->front;	\
	(root)->front->next = (node);	\
	(root)->front = (node);			\
}

// 添加到头部
#define LinkAddToHead(root, node)	\
{									\
	(node)->next = (root)->front;	\
	(node)->front = (root);			\
	(root)->next->front = (node);	\
	(root)->next = (node);			\
}

// 移除节点
#define LinkRemoveSelf(node)			\
{										\
	(node)->front->next = (node)->next;	\
	(node)->next->front = (node)->front;\
	(node)->next = (node)->front = NULL;\
}

// 是否为空
#define LinkEmpty(root) ((root)->next 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值