c语言数据结构链表源代码----笛风读书笔记系列

读书笔记系列之:c语言数据结构链表源代码

                                                                              笛风

                                                                              2013.10.11

在linux下已通过编译,运行毫无压力~


头文件的定义:

Linked_list.h

#ifndef LINKED_LIST_H_
#define LINKED_LIST_H_
#define NOT_FOUND -1
#define SUCCESS 0
typedef struct linked_list_t linked_list_t;
//链表提供接口,可以继续增加功能
struct linked_list_t {
	int (*get_count)(linked_list_t *this);
	int (*remove_first)(linked_list_t *this, void **item);
	void (*insert_last)(linked_list_t *this, void *item);
	void (*destroy)(linked_list_t *this);
};


linked_list_t *linked_list_create(void);

#endif

链表的函数定义:

Linked_list.c

#include "stdlib.h"
#include "stdio.h"
#include "linked_list.h"

typedef struct element_t element_t;
struct element_t {
	void *value;
	element_t *previous;
	element_t *next;
};
//创建链表节点
element_t *element_create(void *value)
{
	element_t *this = malloc(sizeof(element_t));
	this->previous = NULL;
	this->next = NULL;
	this->value = value;
	return (this);
}

typedef struct private_linked_list_t private_linked_list_t;

//链表
struct private_linked_list_t {
	linked_list_t public;
	int count;
	element_t *first;
	element_t *last;
};

static int get_count(private_linked_list_t *this){
	return this->count;
}
static int get_first(private_linked_list_t *this, void **item)
{
	if (this->count == 0)
	{
		return NOT_FOUND;
	}
	*item = this->first->value;
	return SUCCESS;
}
static element_t* remove_element(private_linked_list_t *this, element_t *element)
{
	element_t *next, *previous;

	next = element->next;
	previous = element->previous;
	free(element);
	if (next)
	{
		next->previous = previous;
	}
	else
	{
		this->last = previous;
	}
	if (previous)
	{
		previous->next = next;
	}
	else
	{
		this->first = next;
	}
	if (--this->count == 0)
	{
		this->first = NULL;
		this->last = NULL;
	}
	return next;
}
//线程从任务队列上取下任务
static int remove_first(private_linked_list_t *this, void **item)
{
	//获得第一个元素的值结构体指针
	if (get_first(this, item) == SUCCESS)
	{
		//删除第一个元素
		remove_element(this, this->first);
		return SUCCESS;
	}
	return NOT_FOUND;
}

static void insert_last(private_linked_list_t *this , void * item){
	element_t *element = element_create(item);
	if (this->count == 0)
	{
		/* first entry in list */
		this->first = element;
		this->last = element;
		element->previous = NULL;
		element->next = NULL;
	}
	else
	{
		element_t *old_last_element = this->last;
		element->previous = old_last_element;
		element->next = NULL;
		old_last_element->next = element;
		this->last = element;
	}
	this->count++;
}
static void destroy(private_linked_list_t *this){
	printf("linked list destroy!\n");
}
linked_list_t *linked_list_create(void){
	private_linked_list_t *this = malloc(sizeof(private_linked_list_t));
	this->public.get_count = (int(*)(linked_list_t *))get_count;
	this->public.remove_first = (int(*)(linked_list_t * ,void **item))remove_first;	
	this->public.insert_last = (void(*)(linked_list_t * ,void *item))insert_last;
	this->public.destroy = (void(*)(linked_list_t *))destroy;
	this->first = NULL;
	this->last = NULL;
	this->count = 0;
	return &(this->public);
}

主函数://链表的使用:

#include "stdlib.h"
#include "stdio.h"
#include "linked_list.h"

 
main() 
{
	linked_list_t *list=linked_list_create();
	int a=list->get_count(list);
	int c=25;
	void *b=(void *)&c;
	printf("链表元素的个数为:%d\n",a);
	list->insert_last(list,b);
	printf("链表插入元素成功!\n");
	a=list->get_count(list);
	printf("链表元素的个数为:%d\n",a);
	 
}







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值