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

来源:互联网 发布:mac 转码软件 编辑:程序博客网 时间:2024/04/29 12:10

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

                                                                              笛风

                                                                              2013.10.11

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


头文件的定义:

Linked_list.h

#ifndef LINKED_LIST_H_#define LINKED_LIST_H_#define NOT_FOUND -1#define SUCCESS 0typedef 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
原创粉丝点击