您的位置:首页 > 其它

第四周-项目二—建设“单链表”算法库

2017-09-27 10:54 429 查看
/*
* Copyright (c) 2017,烟台大学计算机学院
* All right reserved.
* 文件名称:main.cpp
* 作者:王华慧
* 完成日期:2017年9月27日
* 版本号:v1.0
*
* 问题描述:建设单链表算法库
* 输入描述:标准函数输入
* 程序输出:标准函数输出
*/

算法库包括两个文件: 
  1.头文件:linklist.h,包含定义顺序表数据结构的代码、宏定义、要实现算法的函数的声明; 
  2.源文件:linklist.cpp,包含实现各种算法的函数的定义 
   采用程序的多文件组织形式,建立如上两个文件,另外再建立一个源文件编制main函数,完成相关的测试工作。 测试工作可以采用“渐进”的思路,每次涉及的函数应该尽可能少。

代码如下:

linklist.h

//linklist.h 存放声明
#pragma once
#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
linklist.cpp
//linklist.cpp 存放定义
#include <stdio.h>
#include <malloc.h>
#include "linklist.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指向要删除的结点

9a91
if (q == NULL)
return false; //若不存在第i个结点,返回false
e = q->data;
p->next = q->next; //从单链表中删除*q结点
free(q); //释放*q结点
return true;
}
}
main.cpp
1.测试单链表的插入 

#include "linklist.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;
} 运行结果;



2.测试单链表的查找及其其他函数

main.cpp

#include "linklist.h"
#include <stdio.h>
int main()
{
LinkList *L;
ElemType e;
InitList(L);
ListInsert(L, 1, 15);
ListInsert(L, 1, 10);
ListInsert(L, 1, 5);
ListInsert(L, 1, 20);
if (ListEmpty(L))
printf("该线性表为空!\n");
else
printf("该线性表长度为:%d\n", ListLength(L));
if (GetElem(L, 1, e))
printf("取得该元素:%d\n", e);
else
printf("没有找到该元素!\n");
if (!LocateElem(L, 15))
printf("没有找到该元素!\n");
else
printf("该元素序号:%d\n", LocateElem(L, 15));
DispList(L);
DestroyList(L);
return 0;
}



总结:有一些小插曲,所建的linklist.h未添加到工程之中让我一阵头疼啊
点链表的算法库和顺序表的算法库还是有些不一样的,实践中更容易观察到他的异同之处。加倍努力,有困难找兄弟。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: