首页 > 其他 > 详细

C基础--双链表的构造

时间:2015-09-26 17:16:46      阅读:197      评论:0      收藏:0      [点我收藏+]
#include <stdio.h>
#include "link.h"

void print_item(link p)
{
    printf("%d\n", p->item);
}
int main(void)
{
    link head, tail, p;        //struct node *head;
    link_init(&head, &tail);        //head => NULL

    p = make_node(3);
    link_insert(&head, &tail, p);    //头插法
    p = make_node(5);
    link_insert(&head, &tail, p);    //头插法
    p = make_node(1);
    link_insert(&head, &tail, p);    //头插法
    p = make_node(8);
    link_insert(&head, &tail, p);    //头插法

    link_travel_head(&head, print_item);    //遍历打印链表数值域
    printf("***************\n");
    link_travel_tail(&tail, print_item);    //遍历打印链表数值域
    printf("***************\n");

    p = link_search(&head, 1);
    if (p != NULL) {
        link_delete(&head, &tail, p);
        free_node(p);
    }
    link_travel_tail(&tail, print_item);    //遍历打印链表数值域
    link_destory(&head, &tail);

    return 0;
}
#ifndef _LINK_H_
#define _LINK_H_
typedef struct node *link;
struct node {
    int item;
    link next;        //struct node *next; 后继
    link pre;        //struct node *pre; 前驱
};

void link_init(link *head, link *tail);
link make_node(int item);
void link_insert(link *head, link *tail, link p);
link link_search(link *head, int key);
void link_delete(link *head, link *tail, link p);
void free_node(link p);
void link_modfie(link p, int key);
void link_destory(link *head, link *tail);
void link_travel_head(link *head, void (*vist)(link));
void link_travel_tail(link *tail, void (*vist)(link));

#endif
#include <stdio.h>
#include <stdlib.h>
#include "link.h"

void link_init(link *head, link *tail)        //struct node **head = &head
{
    //head = NULL;
    *head = *tail = NULL;
}
link make_node(int item)
{
    //link p = (link *)malloc(sizeof(struct node));
    link p = (link)malloc(sizeof(*p));
    p->item = item;                //(*p).itme = item;
    p->next = NULL;                //#define NULL (void *)0
    p->pre = NULL;                //#define NULL (void *)0
    return p;
}
void link_insert(link *head, link *tail, link p)        //头插法
{
    link q; 
    if (*head == NULL) {
        *head = p;
        *tail = p;
        return;
    }

    p->next = *head;
    (*head)->pre = p;
    *head = p;
}
link link_search(link *head, int key)
{
    link p;
    for (p = *head; p != NULL; p = p->next)
        if (p->item == key)
            return p;
    return NULL;
}
void link_delete(link *head, link *tail, link q)
{
    link p;
    if (q == *head) {
        *head = q->next;
        (*head)->pre = NULL;
        return;
    }
    if (q == *tail) {
        *tail = q->pre;
        (*tail)->next = NULL;
        return;
    }
    q->pre->next = q->next;
    q->next->pre = q->pre;
}
void free_node(link p)
{
    free(p);
}
void link_modfie(link p, int key)
{
    p->item = key;
}
void link_destory(link *head, link *tail)
{
    link p= *head, q;
    while (p != NULL) {
        q = p->next;
        free(p);
        p = q;
    }
    *head = NULL; *tail = NULL;
}
void link_travel_head(link *head, void (*vist)(link))
{
    link p;
    for (p = *head; p != NULL; p = p->next)
        vist(p);
}
void link_travel_tail(link *tail, void (*vist)(link))
{
    link p;
    for (p = *tail; p != NULL; p = p->pre)
        vist(p);
}

 

C基础--双链表的构造

原文:http://www.cnblogs.com/zhuyaguang/p/4840967.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!