第四周 项目二 单链表基本操作的实现

/*     
 *Copyright (c) 2016, 烟台大学计算机学院      
*All rights reserved.      *文件名称:test.cpp      
*作者:李良涵    [cpp] view plain copy  
*完成日期:2016年9月23日      
*版本号:v1.0     
 *问题描述:单链表基本操作   
*输入描述:无	
*程序输出:按程序输出
*      
*/ 
问题及代码:
lidt.h
#ifndef LINKLIST_H_INCLUDED
#define LINKLIST_H_INCLUDED


typedef int ElemType;
typedef struct LNode        //定义单链表结点类型
{
    ElemType data;
    struct LNode *next;     //指向后继结点
}LinkList;
void CreateListF(LinkList *&L,ElemType a[],int n);//头插法建立单链表
void CreateListR(LinkList *&L,ElemType a[],int n);//尾插法建立单链表
void InitList(LinkList *&L);  //初始化线性表
void DestroyList(LinkList *&L);  //销毁线性表
bool ListEmpty(LinkList *L);  //判断线性表是否为空
int ListLength(LinkList *L);  //求线性表长度
void DispList(LinkList *L);  //输出线性表
bool GetElem(LinkList *L,int i,ElemType &e);  //求线性表某个数据元素值
int LocateElem(LinkList *L,ElemType e);  //按元素值查找
bool ListInsert(LinkList *&L,int i,ElemType e);  //插入数据元素
bool ListDelete(LinkList *&L,int i,ElemType &e);  //删除数据元素


#endif // LINKLIST_H_INCLUDED
list.cpp
#include <stdio.h>
#include <malloc.h>
#include "lidt.h"




void CreateListF(LinkList *&L,ElemType a[],int n)//头插法建立单链表
{
    LinkList *s;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
    for (i=0; i<n; i++)
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        s->next=L->next;            //将*s插在原开始结点之前,头结点之后
        L->next=s;
    }
}


void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
    r=L;                    //r始终指向终端结点,开始时指向头结点
    for (i=0; i<n; i++)
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        r->next=s;          //将*s插入*r之后
        r=s;
    }
    r->next=NULL;           //终端结点next域置为NULL
}


void InitList(LinkList *&L)
{
    L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点
    L->next=NULL;
}
void DestroyList(LinkList *&L)
{
    LinkList *p=L,*q=p->next;
    while (q!=NULL)
    {
        free(p);
        p=q;
        q=p->next;
    }
    free(p);    //此时q为NULL,p指向尾结点,释放它
}
bool ListEmpty(LinkList *L)
{
    return(L->next==NULL);
}
int ListLength(LinkList *L)
{
    LinkList *p=L;
    int i=0;
    while (p->next!=NULL)
    {
        i++;
        p=p->next;
    }
    return(i);
}
void DispList(LinkList *L)
{
    LinkList *p=L->next;
    while (p!=NULL)
    {
        printf("%d ",p->data);
        p=p->next;
    }
    printf("\n");
}
bool GetElem(LinkList *L,int i,ElemType &e)
{
    int j=0;
    LinkList *p=L;
    while (j<i && p!=NULL)
    {
        j++;
        p=p->next;
    }
    if (p==NULL)            //不存在第i个数据结点
        return false;
    else                    //存在第i个数据结点
    {
        e=p->data;
        return true;
    }
}
int LocateElem(LinkList *L,ElemType e)
{
    LinkList *p=L->next;
    int n=1;
    while (p!=NULL && p->data!=e)
    {
        p=p->next;
        n++;
    }
    if (p==NULL)
        return(0);
    else
        return(n);
}
bool ListInsert(LinkList *&L,int i,ElemType e)
{
    int j=0;
    LinkList *p=L,*s;
    while (j<i-1 && p!=NULL) //查找第i-1个结点
    {
        j++;
        p=p->next;
    }
    if (p==NULL)    //未找到位序为i-1的结点
        return false;
    else            //找到位序为i-1的结点*p
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点*s
        s->data=e;
        s->next=p->next;                        //将*s插入到*p之后
        p->next=s;
        return true;
    }
}
bool ListDelete(LinkList *&L,int i,ElemType &e)
{
    int j=0;
    LinkList *p=L,*q;
    while (j<i-1 && p!=NULL)    //查找第i-1个结点
    {
        j++;
        p=p->next;
    }
    if (p==NULL)                //未找到位序为i-1的结点
        return false;
    else                        //找到位序为i-1的结点*p
    {
        q=p->next;              //q指向要删除的结点
        if (q==NULL)
            return false;           //若不存在第i个结点,返回false
        e=q->data;
        p->next=q->next;        //从单链表中删除*q结点
        free(q);                //释放*q结点
        return true;
    }
}
main.cpp
#include "lidt.h"
int main()
{
    LinkList *L;
    InitList(L);
    ListInsert(L, 1, 15);
    ListInsert(L, 1, 10);
    ListInsert(L, 1, 5);
    ListInsert(L, 1, 20);
    DispList(L);
    DestroyList(L);
    return 0;
}

运行结果


心得体会:

 还好。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、链接存储方法<br>  链接方式存储的线性表简称为链表(Linked List)。<br>  链表的具体存储表示为:<br>  ① 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的,也可以是不连续的)<br>  ② 链表中结点的逻辑次序和物理次序不一定相同。为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link))<br>注意:<br>  链式存储是最常用的存储方式之一,它不仅可用来表示线性表,而且可用来表示各种非线性的数据结构。<br><br>2、链表的结点结构<br> ┌──┬──┐<br> |data | next│<br> └──┴──┘ <br>  data域--存放结点值的数据域<br>  next域--存放结点的直接后继的地址(位置)的指针域(链域)<br>注意:<br>   ①链表通过每个结点的链域将线性表的n个结点按其逻辑顺序链接在一起的。<br>  ②每个结点只有一个链域的链表称为单链表(Single Linked List)。<br>3、头指针head和终端结点指针域的表示<br>  单链表中每个结点的存储地址是存放在其前趋结点next域中,而开始结点无前趋,故应设头指针head指向开始结点。<br>注意:<br>  链表由头指针唯一确定,单链表可以用头指针的名字来命名。<br>【例】头指针名是head的链表可称为表head。<br>  终端结点无后继,故终端结点的指针域为空,即NULL<br>4、单链表类型描述<br> typedef char DataType; /* 假设结点的数据域类型为字符 */<br> typedef struct node { /* 结点类型定义 */<br> DataType data; /* 结点的数据域 */<br> struct node *next; /* 结点的指针域 */<br> } ListNode;<br> typedef ListNode *LinkList;<br> ListNode *p;<br> LinkList head;<br> 注意:<br>  ①LinkList和ListNode *是不同名字的同一个指针类型(命名的不同是为了概念上更明确)<br>  ②LinkList类型的指针变量head表示它是单链表的头指针<br>  ③ListNode *类型的指针变量p表示它是指向某一结点的指针<br><br>6、指针变量和结点变量<br><br><br>┌────┬────────────┬─────────────┐ <br>│    │    指针变量    │     结点变量    │<br>├────┼────────────┼─────────────┤<br>│ 定义 │在变量说明部分显式定义 │在程序执行时,通过标准 │<br>│ │ │函数malloc生成 │<br>├────┼────────────┼─────────────┤<br>│ 取值 │ 非空时,存放某类型结点 │实际存放结点各域内容 │<br>│ │ 的地址 | │<br>├────┼────────────┼─────────────┤<br>│操作方式│ 通过指针变量名访问 │ 通过指针生成、访问和释放 │<br>└────┴────────────┴─────────────┘<br> <br>①生成结点变量的标准函数<br>  p = malloc( sizeof(ListNode) );<br> /* 函数malloc分配一个类型为ListNode的结点变量的空间,并将其首地址放入指针变量p中 */<br>②释放结点变量空间的标准函数 <br>  free(p); /* 释放p所指的结点变量空间 */<br>③结点分量的访问 <br>  利用结点变量的名字*p访问结点分量<br> 方法一:(*p).data和(*p).next<br> 方法:p-﹥data和p-﹥next<br>④指针变量p和结点变量*p的关系 <br>  指针变量p的值——结点地址<br>  结点变量*p的值——结点内容<br>  (*p).data的值——p指针所指结点的data域的值<br>  (*p).next的值——*p后继结点的地址<br>  *((*p).next)——*p后继结点<br><br>注意:<br>   ① 若指针变量p的值为空(NULL),则它不指向任何结点。此时,若通过*p来访问结点就意味着访问一个不存在的变量,从而引起程序的错误。<br>   ② 有关指针类型的意义和说明方式的详细解释,【参考C语言的有关资料】。<br>

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值