当前位置:文档之家› (完整版)数据结构实验报告全集

(完整版)数据结构实验报告全集

数据结构实验报告全集实验一线性表基本操作和简单程序1 .实验目的(1 )掌握使用Visual C++ 6.0 上机调试程序的基本方法;(2 )掌握线性表的基本操作:初始化、插入、删除、取数据元素等运算在顺序存储结构和链表存储结构上的程序设计方法。

2 .实验要求(1 )认真阅读和掌握和本实验相关的教材内容。

(2 )认真阅读和掌握本章相关内容的程序。

(3 )上机运行程序。

(4 )保存和打印出程序的运行结果,并结合程序进行分析。

(5 )按照你对线性表的操作需要,重新改写主程序并运行,打印出文件清单和运行结果实验代码:1)头文件模块#include iostream.h>// 头文件#include<malloc.h>// 库头文件------ 动态分配内存空间typedef int elemtype;// 定义数据域的类型typedef struct linknode// 定义结点类型{elemtype data;// 定义数据域struct linknode *next;// 定义结点指针}nodetype;2)创建单链表nodetype *create()// 建立单链表,由用户输入各结点data 域之值,// 以0 表示输入结束{elemtype d;// 定义数据元素dnodetype *h=NULL,*s,*t;// 定义结点指针int i=1;cout<<" 建立一个单链表"<<endl;while(1){cout <<" 输入第"<< i <<" 结点data 域值:cin >> d;if(d==0) break;// 以0 表示输入结束if(i==1)// 建立第一个结点{h=(nodetype*)malloc(sizeof(nodetype));//表示指针h h->data=d;h->next=NULL;t=h;//h 是头指针}else// 建立其余结点{s=(nodetype*) malloc(sizeof(nodetype)); s->data=d;s->next=NULL;t->next=s;t=s;//t 始终指向生成的单链表的最后一个节点i++;}return h;}3) 输出单链表中的元素void disp(nodetype*h)// 输出由h 指向的单链表的所有data 域之值{ nodetype *p=h;cout<<" 输出一个单链表:"<<endl<<" ";if(p==NULL)cout<<" 空表";while(p!=NULL){cout<<p->data<<" ";p=p->next;}cout<<endl;}4) 计算单链表的长度int len(nodetype *h)// 返回单链表的长度{int i=0;nodetype *p=h;while(p!=NULL){p=p->next;i++;}return i;}5) 寻找第i 个节点nodetype *find(nodetype *h,int i)// 返回第i 个节点的指针{nodetype *p=h;int j=1;if(i>len(h)||i<=0)return NULL;//i 上溢或下溢celse{while (p!=NULL&&j<1)// 查找第i 个节点,并由p 指向该节点{j++;p=p->next;}return p;}6)单链表的插入操作nodetype *ins(nodetype *h,int i,elemtype x)// 在单链表head 中第i 个节点// ( i>=0 )之后插入一个data 域为x 的节点{nodetype *p,*s;s=(nodetype*)malloc(sizeof(nodetype));// 创建节点ss->data=x;s->next=NULL;if(i==0)//i=0:s 作为该单链表的第一个节点{s->next=h;h=s;}else{p=find(h,i);// 查找第i 个节点,并由p 指向该节点if(p!=NULL){s->next=p->next;p->next=s;}return h;}}7)单链表的删除操作nodetype *del(nodetype *h,int i)// 删除第i 个节点{nodetype *p=h, *s;int j=1;if(i==1)// 删除第1 个节点{h=h->next;free(p);}else{p=find(h,i-1);// 查找第i-1 个节点,并由p 指向该节点if(p!=NULL&&p->next!=NULL){s=p->next;//s 指向要删除的节点p->next=s->next;free(s);}else cout<<" 输入i 的值不正确"<<endl;}return h;}8) 释放节点空间void dispose(nodetype *h)// 释放单链表的所有节点占用的空间{nodetype *pa=h,*pb;if(pa!=NULL){pb=pa->next;if(pb==NULL)// 只有一个节点的情况free(pa);else{while (pb!=NULL)// 有两个及以上节点的情况{free(pa);pa=pb;pb=pb->next;}free(pa);}}}9) 主程序模块:#include"slink.h"// 包含头文件slinkvoid main()head=create();// 创建一个单链表disp(head);// 输出单链表{nodetype *head;// 定义节点指针变量cout<<" 单链表长度:"<<len(head)<<endl;ins(head, 2,0);// 在第二个节点之后插入以0 为元素的节点disp(head);// 输出新链表del(head,2);// 删除第二个节点disp(head);// 输出新链表}5.实验结果建立一个单链表:输入第 1 结点data 域值:1输入第 2 结点data 域值:2输入第 3 结点data 域值:3输入第 4 结点data 域值:4输入第 5 结点data 域值:5输入第 6 结点data 域值:6输入第7 结点data 域值:7输入第8 结点data 域值:8输入第9 结点data 域值:9输入第10 结点data 域值0:输出一个单链表:单链表长度:9输出一个单链表:1 02345678 9输出一个单链表:1 2 3 4 5 6 7 8实验二顺序栈的实现1. 实验目的掌握顺序栈的基本操作:初始化栈、判栈空否、入栈、出栈、取栈顶数据元素等运算以及程序实现方法。

2. 实验要求(1 )认真阅读和掌握和本实验相关的教材内容。

(2 )分析问题的要求,编写和调试完成程序。

(3 )保存和打印出程序的运行结果,并分析程序的运行结果。

3. 实验内容利用栈的基本操作实现一个判断算术表达式中包含圆括号、方括号是否正确配对的程序。

具体完成如下:(1 )定义栈的顺序存取结构。

(2 )分别定义顺序栈的基本操作(初始化栈、判栈空否、入栈、出栈等)。

(3 )定义一个函数用来判断算术表达式中包含圆括号、方括号是否正确配对。

其中,括号配对共有四种情况:左右括号配对次序不正确;右括号多于左括号;左括号多于右括号;左右括号匹配正确。

(4 )设计一个测试主函数进行测试。

(5 )对程序的运行结果进行分析。

实验代码:#i nclude vstdio.h >#defi ne MaxSize 100 typedef struct{int data[MaxSize];int top;}SqStack;void In itStack(SqStack *st) // 初始化栈{st->top=-1;}int StackEmpty(SqStack *st) // 判断栈为空{return (st->top==-1);}void Push(SqStack *st, int x) // 元素进栈{if(st->top==MaxSize-1) printf("栈上溢出!\n");else{st->top++; st->data[st->top]=x;}}void Pop(SqStack *st) // 退栈{if(st->top==-1) printf("栈下溢出\n");elsest->top--;}int Gettop(SqStack *st) // 获得栈顶元素{if(st->top==-1){prin tf("栈空\n");return 0;} elsereturn st->data[st->top];void Display(SqStack *st) // 打印栈里元素{int i;printf(" 栈中元素:");for(i=st->top;i>=0;--i)prin tf("%d ",st->data[i]);prin tf("\n");}int mai n() // 测试{SqStack L;SqStack *st=&L;In itStack(st);printf(" 栈空:%d\n",StackEmpty(st));for(int i=1;i<10;++i)Push(st,i);Display(st);printf("退一次栈\n");Pop(st);printf("栈顶元素:%d\n",Gettop(st)); Pop(st);Display(st); return 0;}实验结果:实验三串的基本操作和简程序1.实验目的掌握串基本操作:初始化、联接、替换、子串等运算在堆分配存储储结构上的程序设计方法。

相关主题