首页 > 其他 > 详细

数据结构学习——链表的使用(程序化)

时间:2015-03-22 22:27:50      阅读:120      评论:0      收藏:0      [点我收藏+]

看了一点网上的代码,结合自己对链表的理解。将对链表常用的操作集合程序化如下:

#include<stdio.h>
#include<stdlib.h>

typedef struct Node
{
    int Val;
    struct Node *next;
}List;

List *list_add(List **p,int Val);//此处是二级指针
void List_Print(List *p);
List *list_insert(List **p,int Val,int i);//i为插入的位置 Val插入的值
List *list_remove(List **p,int i);//删除指定位置i的值


int main()
{
    List *n=NULL;
    list_add(&n,0);
    list_add(&n,1);
    list_add(&n,2);
    list_add(&n,3);
    list_add(&n,4);
    list_insert(&n,5,3);
    list_insert(&n,6,2);
    list_remove(&n,2);
    list_remove(&n,3);
    List_Print(n);
    return 0;
}

List *list_remove(List **p,int i)//删除指定位置i的值
{
    int count=0;
    List *q,*a;
    a=*p;
    if(p==NULL)
        return NULL;
    for(count=0;count<(i-2);count++)
    {
        a=a->next;
        if(a==NULL)
            return NULL;
    }
    q=a->next;//后继元
    a->next=q->next;
    return *p;
}

List *list_insert(List **p,int Val,int i)
{
    int count=0;
    List *q,*a;
    a=*p;
    if(p==NULL)
        return NULL;
    for(count=0;count<(i-2);count++)
    {
        a=a->next;
        if(a==NULL)
            return NULL;
    }
    q=a->next;//后继元

    List *temp=(List *)malloc(sizeof(List));
    temp->next=q;
    temp->Val=Val;
    a->next=temp;
    return *p;
}

List *list_add(List **p,int Val)//此处是二级指针
{
    if(p==NULL)
        return NULL;

    List *temp=(List *)malloc(sizeof(List));
    temp->next=*p;
    temp->Val=Val;
    *p=temp;  //头指针移动到开始处 *P在此处的作用为头指针

    return *p;
}

void List_Print(List *p)
{
    if(p==NULL)
        printf("list is empty\n");
    while(p)
    {
         printf("%d\t",p->Val);
         p=p->next;
    }
}


数据结构学习——链表的使用(程序化)

原文:http://blog.csdn.net/u010275850/article/details/44542357

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