- 1、本文档共18页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验一 线性表的基本操作及其应用
实验目的
1、帮助读者复习C++语言程序设计中的知识。
2、熟悉线性表的逻辑结构。
3、熟悉线性表的基本运算在两种存储结构上的实现,其中以熟悉链表的操作为侧重点。题目一:单链表的基本操作(*)
题目二:约瑟夫环(**)[问题描述]
实现带头结点的单链表的建立、求长度,取元素、修改元素、插入、删除等单链表的基本操作。
[基本要求]
(2)输出单链表中的数据元素 [测试数据]
由学生任意指定。
Data *next
主要思想:
插入:
删除:
本函数包含八个模块
主函数int main() :初始化一个链表L,显示菜单,主要语句:switch语句,while语句,goto语句。
创建并输入链表数据linklist createlist(),在该函数中创建头结点,并输入结点上的数据。
伪代码:while(当x!=00)
{
p = new list;
p-data = x;
p-next = NULL;
q-next = p;
q = p;
}
显示链表数据void show(linklist L)
先判断是否是空表,再逐个寻找想要的元素。
主要代码:
while(p)
{
coutp-data\t;
p = p-next;
}
获取链表长度int getlength(linklist L)
先判断是否为空,再遍历链表,算出链表长度。
主要代码:
while(p)
{
p = p-next;
length++;
}
获取第i个元素int getdata(linklist L,int i)
1)当0ilength时,遍历链表,找到第i个元素。
2)主要代码:
while(pji)
{
j++;
p = p-next;
}
改变链表数据int changedata(linklist L,int e,int d)
1)找到要修改的值e,再把d赋值给e.
2)主要代码:
while(pp-data!=e)
{
p = p-next;
}
if(!p)
return ERROR;
p-data = d;
插入一个结点linklist insertlist(linklist L,int i,int e)
1)因为要插入第i个元素,所以要先找到第i-1个元素,在i-1后面插入。
2)主要代码:
s-data = e;
s-next = p-next ;
p-next = s;
删除一个结点linklist deletelist(linklist L,int i)
1)同插入差不多,先找到第i-1个元素,然后再把i-1结点指针域指向原本指向结点的下一个,把中间那个删除,再free,释放空间,
主要代码:
q = p-next;
p-next =q-next;
free(q);
实验过程
图1、登陆界面
图2、功能键1,2,3,4的实现
图3、功能键5、6的实现
图4、功能键7、0的实现
六、调试及感受
又是一次课设时,每次写程序总会遇到大大小小的毛病,就不断的调试调试,觉得写代码是需要很大的耐心,一直琢磨,一直分析,一直改,直至完美。可是当代码运行到自己想要的程度时,内心是那么的自豪,那么的傲娇,那么的兴奋,仿佛心长了翅膀似的,飞到高空翱翔去了,呵呵,感觉不错。不过,我希望自己下次不用再借鉴网上的代码,就能够自己迎仞有余,加油,我可以的!
并且谢谢老师的教导,老师您辛苦了!!!
七、源代码
#includeiostream
#includestdio.h
#includemalloc.h
#define ERROR -1;
using namespace std;
typedef struct node{
int data;
node *next;
}list,*linklist;
linklist createlist()//输入链表数据
{
linklist head;
head = new list;
head-next = NULL;
list *p,*q;
q = head;
int x;
cinx;
while(x!=00)
{
p = new list;
p-data = x;
p-next = NULL;
q-next = p;
q = p;
cinx;
}
return head;
}
void sho
文档评论(0)