第一篇:21-葛义杰 算法与数据结构实验册
金陵科技学院实验报告
学 生 实 验 报 告 册
课程名称:
学生学号:
所属院部:
(理工类)
算法与数据结构 专业班级:15计算机科学与技术(单)
1513902021 学生姓名: 葛义杰
计算机工程学院 指导教师: 章海鸥
2016 ——2017 学年 第 1 学期
金陵科技学院教务处制
金陵科技学院实验报告
实验报告书写要求
实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。
实验报告书写说明
实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。
填写注意事项
(1)细致观察,及时、准确、如实记录。(2)准确说明,层次清晰。
(3)尽量采用专用术语来说明事物。
(4)外文、符号、公式要准确,应使用统一规定的名词和符号。(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。
实验报告批改说明
实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。
实验报告装订要求
实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。
金陵科技学院实验报告
实验项目名称: 顺序表 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间:
金陵科技学院实验报告
实验1 顺序表
一、实验目的和要求
掌握顺序表的定位、插入、删除等操作。
二、实验仪器和设备
VC6.0
三、实验内容与过程(含程序清单及流程图)
1、必做题
(1)编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。编写主函数测试结果。
(2)编写顺序表定位操作子函数,在顺序表中查找是否存在数据元素x。如果存在,返回顺序表中和x值相等的第1个数据元素的序号(序号从0开始编号);如果不存在,返回-1。编写主函数测试结果。(3)在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。
解题思路:首先查找插入的位置,再移位,最后进行插入操作;从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置;然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。
(4)删除顺序表中所有等于X的数据元素。
2、选做题
(5)已知两个顺序表A和B按元素值递增有序排列,要求写一算法实现将A和B归并成一个按元素值递减有序排列的顺序表(允许表中含有值相同的元素)。
程序清单:
1.#include
void CreateList(sequenlist *L,int n){int i;printf(“please input n numbersn”);for(i=0;i 金陵科技学院实验报告 { scanf(“%d”,&L->data[i]);(*L).last=n;} } void PrintList(sequenlist *L,int n){int i;printf(“the sequenlist isn”);for(i=0;i void CreateList(sequenlist *L,int n){int i;printf(“请你输入数据元素:n”);for(i=0;i main(){ int i,x,a;int n;sequenlist L;L.last=0;printf(“请你输入顺序表的长度:n n=”);scanf(“%d”,&n);CreateList(&L,n);//调用顺序表的建立函数 金陵科技学院实验报告 // PrintList(&L,n);//调用顺序表的 打印输出函数 // printf(“n”);printf(“请输入要查找的数据元素X:nx=”);scanf(“%d”,&x);a=Seek(&L,x);if(a==-1)printf(“没有找到你所要找的数据元素!”);else {printf(“你所要查找的数据元素位置是:”);printf(“%d”,a);} getchar();getchar();} 3.#include struct{ datatype data[maxsize];int last;}sequenlist; void CreateList(sequenlist *L,int n){int i;printf(“请你输入数据元素:n”);for(i=0;i { scanf(“%d”,&(*L).data[i]); }(*L).last=n-1;} InsertaInteger(sequenlist *L,int c){ int i,j,m; for(i=0;i<(*L).last;i++) { if(c<=(*L).data[i]) {m=i;break;} } (*L).last++; for(j=(*L).last;j>=m;j--) { (*L).data[j+1]=(*L).data[j]; (*L).data[m]=c; } (*L).last++; for(i=0;i<(*L).last;i++) printf(“%d ”,(*L).data[i]); } main(){ int i,x;int a,c,n;sequenlist L;L.last=0; 金陵科技学院实验报告 printf(“请你输入顺序表的长度:n n=”);scanf(“%d”,&n);CreateList(&L,n);//调用顺序表的建立函数 printf(“n请输入你要插入的数据元素C:”);scanf(“%d”,&c);InsertaInteger(&L,c);getchar();getchar();} 4.#include 金陵科技学院实验报告 i=Get(&L,x);if(i==-1)printf(“你所要删除的元素不存在”);else { while(i<(*L).last+1){if((*L).data[i]==x){(*L).data[i]=(*L).data[i+1];i--;(*L).last--;} i++;} } for(i=0;i<(*L).last+1;i++)printf(“%d ”,(*L).data[i]);} main(){ int i,x,a,m;int n;sequenlist L;L.last=0;printf(“请你输入顺序表的长度:n n=”);scanf(“%d”,&n);CreateList(&L,n);//调用顺序表的建立函数 printf(“n”);printf(“请你输入要删除的数据元素m:”);scanf(“%d”,&m);Deleate(&L,m); 金陵科技学院实验报告 getchar();getchar();} 四、实验结果与分析(程序运行结果及其分析)1.2.3.4.金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会)编程要求我们有足够的耐心,细细推敲。越着急可能就越无法得到我们想要的结果,遇到不会的问题要多多请教,知识是在实践与向别人请教的过程中积累的,所以问是至关重要的,只要肯下功夫很多东西都是可以完成的。 金陵科技学院实验报告 实验项目名称: 单链表 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验2 单链表 一、实验目的和要求 1、实验目的 掌握单链表的定位、插入、删除等操作。 2、实验要求 (1)注意链表的空间是动态分配的,某结点不用之后要及时进行物理删除,以便释放其内存空间。 (2)链表不能实现直接定位,一定注意指针的保存,防止丢失。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个单链表,并逐个输出单链表中所有数据元素。(2)在递增有序的单链表中插入一个新结点x,保持单链表的有序性。 解题思路:首先查找插入的位置然后进行插入操作;从第一个结点开始找到第一个大于该新结点值的结点即为插入位置;然后在找到的此结点之前插入新结点;注意保留插入位置之前结点的指针才能完成插入操作。 (3)编写实现带头结点单链表就地逆置的子函数,并编写主函数测试结果。 2、选做题 已知指针LA和LB分别指向两个无头结点单链表的首元结点。要求编一算法实现,从表LA中删除自第i个元素起共len个元素后,将它们插入到表LB中第j个元素之前。 程序清单: 1.#include linklist *CREATLINKLISTR(){int a;linklist *head,*s,*r;head=NULL;r=NULL;printf(“请输入单链表的数据元素:n”); 金陵科技学院实验报告 scanf(“%d”,&a);while(a!=-1){ s=(linklist*)malloc(sizeof(linklist));s->data=a;if(head==NULL)head=s;else r->next=s;r=s;scanf(“%d”,&a);} if(r!=NULL)r->next=NULL;return head;} void *PRINTLINKLIST(linklist *q){ while(q){ printf(“%d ”,q->data);q=q->next;} } main(){linklist *p;p=CREATLINKLISTR();printf(“n”);printf(“你所输入的单链表为:n”);PRINTLINKLIST(p);getchar();getchar();} 2.#include linklist *CREATLINKLISTR(){int a;linklist *head,*s,*r;head=NULL;r=NULL;printf(“请输入单链表的数据元素(输入时数据元素递增):n”);scanf(“%d”,&a); 金陵科技学院实验报告 while(a!=-1){ s=(linklist*)malloc(sizeof(linklist));s->data=a;if(head==NULL)head=s;else r->next=s;r=s;scanf(“%d”,&a);} if(r!=NULL)r->next=NULL;return head;} void *PRINTLINKLIST(linklist *q){ while(q){ printf(“%d ”,q->data);q=q->next;} } linklist *Insert(linklist *head,int x){linklist *s,*q;s=(linklist*)malloc(sizeof(linklist));s->data=x;q=head;if(q->data>x){ s->next=q;head=s;} else while(q!=NULL){ if(q->next->data>x){ s->next=q->next;q->next=s;break;} 金陵科技学院实验报告 q=q->next;} q=head; PRINTLINKLIST(q);} main(){linklist *p;int x;p=CREATLINKLISTR();printf(“你所建立的单链表为:n”);PRINTLINKLIST(p);printf(“n”);printf(“请输入在以上有序递增的单链表中插入数据x:n”);scanf(“%d”,&x);Insert(p,x);getchar();getchar();} 3.#include linklist *CREATLINKLISTR(){int a;linklist *head,*s,*r;head=(linklist*)malloc(sizeof(linklist));r=head;printf(“请输入单链表中的数据元素n”);scanf(“%d”,&a);while(a!=1){ s=(linklist*)malloc(sizeof(linklist));s->data=a;r->next=s;r=s;scanf(“%d”,&a);} r->next=NULL; 金陵科技学院实验报告 return head;} void *PRINTLINKLIST(linklist *q){ while(q){ printf(“%d ”,q->data);q=q->next;} } linklist *InverseLinklist(linklist *q){linklist *p,*head;p=head->next;if(p!=NULL){ p=p->next;head->next->next=NULL;} while(p!=NULL){ q=p->next;p->next=head->next;head->next=p;p=q;} printf(“n单链表被逆置后为n”);PRINTLINKLIST(head->next);} int main(){linklist *p;p=CREATLINKLISTR();// PRINTLINKLIST(p->next);InverseLinklist(p);getchar();getchar();} 四、实验结果与分析(程序运行结果及其分析) 1金陵科技学院实验报告 2.3.五、实验体会(遇到问题及解决办法,编程后的心得体会) 链表的空间是动态分配的,某结点不用之后要及时进行物理删除,以便释放其内存空间。链表不能实现直接定位,一定注意指针的保存,防止丢失。 金陵科技学院实验报告 实验项目名称: 堆栈和队列 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验3 堆栈和队列 一、实验目的和要求 (1)掌握应用栈解决问题的方法。(2)掌握利用栈进行表达式求和的算法。 (3)掌握队列的存储结构及基本操作实现,并能在相应的应用问题中正确选用它们。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)判断一个算术表达式中开括号和闭括号是否配对。(2)测试“汉诺塔”问题。 (3)假设称正读和反读都相同的字符序列为”回文”,试写一个算法判别读入的一个以’@’为结束符的字符序列是否是“回文”。 2、选做题 在顺序存储结构上实现输出受限的双端循环队列的入列和出列算法。设每个元素表示一个待处理的作业,元素值表示作业的预计时间。入队列采取简化的短作业优先原则,若一个新提交的作业的预计执行时间小于队头和队尾作业的平均时间,则插入在队头,否则插入在队尾。程序清单: 1. 判断一个算术表达式中开括号和闭括号是否配对。#include datatype data[maxsize];int top;} seqstack; int match(char exp[],int n){ char st[maxsize];//ÉèÖÃÒ»¸öÕ»£¬ÓÃÀ´´æ·ÅɨÃè±í´ïʽÖеÄÀ¨ºÅ int top=-1,i=0,tag=1;while(i if(exp[i]=='('||exp[i]=='['||exp[i]=='{')//Óöµ½'(''[''{',Ôò½«ÆäÈëÕ» { top++; st[top]=exp[i]; 金陵科技学院实验报告 } if(exp[i]==')')//Óöµ½')',ÈôÕ»¶¥ÊÇ'(',Ôò¼ÌÐø´¦Àí£¬·ñÔòÒÔ²»Åä¶Ô·µ»Ø if(st[top]=='(')top--; else tag=0; if(exp[i]==']') if(st[top]=='[')top--; else tag=0; if(exp[i]=='}') if(st[top]=='{')top--; else tag=0; i++;} if(top>=0)tag=0;//ÈôÕ»²»¿Õ£¬Ôò²»Åä¶Ô return tag;} main(){ int tag,i;char exp[7]={'(','+','(','2','-','4',')'}; printf(“ÇëÊäÈëÒ»¸öËãʽ±í´ïʽ£ºn”); for(i=0;i<7;i++) exp[i]=getchar();tag=match(exp,7);if(tag) printf(“Ëãʽ±í´ïʽÖеĿªÀ¨ºÅºÍ±ÕÀ¨ºÅÅä¶Ô¡£”);else printf(“Ëãʽ±í´ïʽÖеĿªÀ¨ºÅºÍ±ÕÀ¨ºÅ²»Åä¶Ô£¡”);getchar();getchar();} 2.#include void move(char x,char z){printf(“%c-->”,x);printf(“%cn”,z);} void Hanoi(int n,char x, char y,char z){ if(n==1)move(x,z);else {Hanoi(n-1,x,z,y);move(x,z);Hanoi(n-1,y,x,z);} } main(){ int m;printf(“请你输入A上面的碟子总数”);scanf(“%d”,&m);Hanoi(m,'A','B','C');getchar();getchar();} 金陵科技学院实验报告 3.#include 四、实验结果与分析(程序运行结果及其分析). 金陵科技学院实验报告 2.3. 五、实验体会(遇到问题及解决办法,编程后的心得体会) 链栈则没有上溢的限制,它就象是一条一头固定的链子,可以在活动的一头自由地增加链环(结点)而不会溢出,链栈不需要在头部附加头结点,因为栈都是在头部进行操作的,如果加了头结点,等于要在头结点之后的结点进行操作,反而使算法更复杂,所以只要有链表的头指针就可以了。 金陵科技学院实验报告 实验项目名称: 串 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验4 串 一、实验目的和要求 掌握串的存储及应用。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写输出字符串s中值等于字符ch的第一个字符的函数,并用主函数测试结果。 (2)编写输出字符串s中值等于字符ch的所有字符的函数,并用主函数测试结果。 解题思路:可以将第一题程序改进成一个子函数,在本题中循环调用。(3)设字符串采用单字符的链式存储结构,编程删除串s从位置i开始长度为k的子串。 2、选做题 假设以链结构表示串,编写算法实现将串S插入到串T中某个字符之后,若串T中不存在这个字符,则将串S联接在串T的末尾。 提示:为提高程序的通用性,插入位置字符应设计为从键盘输入。程序清单: 1.#include int seekfirst(char a[],char x){int i;for(i=0;i main(){int location;char ch;char s[50];gets(s);scanf(“%c”,&ch);location=seekfirst(s,ch); 金陵科技学院实验报告 printf(“%d”,location);getchar();getchar();} 2. #include void seeklocation(char a[],char x){int i;for(i=0;i main(){ char ch;char s[50];gets(s);scanf(“%c”,&ch);seeklocation(s,ch);getchar();getchar();} 3. #include } m++;} while(h!=NULL){ h=h->next;n++; if(n==k) 金陵科技学院实验报告 break; } p->next=h->next;f=head->next;while(f!=NULL){ printf(“%c”,f->data);f=f->next; } } main(){char ch;int i,k;linkstring *s,*head,*r,*q; head=(linkstring*)malloc(sizeof(linkstring));r=head;ch=getchar();while(ch!='n'){ s=(linkstring *)malloc(sizeof(linkstring));s->data=ch;r->next=s;r=s;ch=getchar(); } r->next=NULL;q=head;printf(“输入位置和长度”);scanf(“%d%d”,&i,&k);printf(“%d %dn”,i,k);DeleateSmallString(q,i,k); getchar();getchar(); } 四、实验结果与分析(程序运行结果及其分析)1. 2.金陵科技学院实验报告 3.五、实验体会(遇到问题及解决办法,编程后的心得体会) 在串顺序存储结构中,实现串操作的原操作为字符序列的复制串与线性表在逻辑结构上极为相似,区别仅在于串的数据对象约束为字符集 ;在基本操作上差别很大,线性表的基本操作大多数以单个元素作为操作对象,而串的基本操作通常以 串的整体 作为操作对象。两个串相等的充分必要条件是两个串的长度相等且各个对应位置的字符都相等。空串是指 不含任何字符的串,空格串是指仅含空格字符的串。 金陵科技学院实验报告 实验项目名称: 二叉树 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验5 二叉树 一、实验目的和要求 (1)掌握二叉树的生成,以及前、中、后序遍历算法。(2)掌握应用二叉树递归遍历思想解决问题的方法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)建立一棵二叉树。对此树进行前序遍历、中序遍历及后序遍历,输出遍历序列。 (2)在第一题基础上,求二叉树中叶结点的个数。(3)在第一题基础上,求二叉树中结点总数。(4)在第一题基础上,求二叉树的深度。 2、选做题 已知一棵完全二叉树存于顺序表sa中,sa.elem[1…sa.last]存储结点的值。试编写算法由此顺序存储结构建立该二叉树的二叉链表。 解题思路:根据完全二叉树顺序存储的性质来确定二叉树的父子关系即“还原”了二叉树,之后再按照二叉树二叉链表的构造方法进行建立。完全二叉树顺序存储的一个重要性质为,第i个结点的左孩子是编号为2i的结点,第i个结点的右孩子是编号为2i+1的结点。程序清单: 1.#include bitree *creattree()//建立二叉树,函数返回指向根的指针 {bitree *Q[maxsize];//队列Q为bitree指针类型的数组 char ch; 金陵科技学院实验报告 int front,rear;//队头队尾指针 bitree *root,*s;root=NULL;//置空二叉树 front=1;rear=0;//置空队列 ch=getchar();//输入第一个字符 while(ch!='n')//不是结束符的时候重复做 { s=NULL;if(ch!='@')//空格表示虚结点,不是虚结点时建立新的结点 { s=(bitree*)malloc(sizeof(bitree));s->data=ch;s->lchild=NULL;s->rchild=NULL;} rear++;Q[rear]=s;//新结点地址入队 if(rear==1)root=s;//结点 else {if(s&&Q[front])//是虚结点 if(rear%2==0)Q[front]->lchild=s;//rear是左孩子 else Q[front]->rchild=s;//孩子已处理完毕,出队列 if(rear%2==1)front++;} ch=getchar();// } return root;//} //前序遍历二叉树并计算二叉树的叶结点个数 void leaf(bitree *T){ if(T){ if(T->lchild==NULL&&T->rchild==NULL)m++;leaf(T->lchild);leaf(T->rchild); 将虚结点指针NULL或输入第一个结点为根孩子和双亲结点均不为偶数,新结点结点*Q[front]的两个输入下一个字符 返回头指针 金陵科技学院实验报告 } } //主函数 void main(){ bitree *L;printf(“建立的二叉树为:n”);L=creattree();leaf(L);printf(“二叉树叶节点个数为:n”);printf(“%d”,m);getchar();getchar();} 2. #include //二叉树的建立函数 bitree *creattree()//建立二叉树,函数返回指向根的指针 {bitree *Q[maxsize];//队列Q为bitree指针类型的数组 char ch;int front,rear;//队头队尾指针 bitree *root,*s;root=NULL;//置空二叉树 front=1;rear=0;//置空队列 ch=getchar();//输入第一个字符 while(ch!='n')//不是结束符的时候重复做 金陵科技学院实验报告 { s=NULL;if(ch!='@')//空格表示虚结点,不是虚结点时建立新的结点 { s=(bitree*)malloc(sizeof(bitree));s->data=ch;s->lchild=NULL;s->rchild=NULL;} rear++;Q[rear]=s;//新结点地址入队 if(rear==1)root=s;//结点 else {if(s&&Q[front])//是虚结点 if(rear%2==0)Q[front]->lchild=s;//rear是左孩子 else Q[front]->rchild=s;//孩子已处理完毕,出队列 if(rear%2==1)front++;} ch=getchar();// } return root;//} 将虚结点指针NULL或输入第一个结点为根孩子和双亲结点均不为偶数,新结点结点*Q[front]的两个输入下一个字符 返回头指针 金陵科技学院实验报告 //二叉树的深度函数 int high(bitree *T){int m,n;if(T==NULL)return 0;else m=high(T->lchild);n=high(T->rchild);return((m>n?m:n)+1);} //主函数 void main(){int m;bitree *L;printf(“建立的二叉树为:n”);L=creattree();m=high(L);printf(“二叉树的高度为:n”);printf(“%d”,m);getchar();getchar();} 3.。 #include 金陵科技学院实验报告 struct node *lchild,*rchild;}bitree;int m=0;//二叉树的建立函数 bitree *creattree()//建立二叉树,函数返回指向根的指针 {bitree *Q[maxsize];//队列Q为bitree指针类型的数组 char ch;int front,rear;//队头队尾指针 bitree *root,*s;root=NULL;//置空二叉树 front=1;rear=0;//置空队列 ch=getchar();//输入第一个字符 while(ch!='n')//不是结束符的时候重复做 { s=NULL;if(ch!='@')//空格表示虚结点,不是虚结点时建立新的结点 { s=(bitree*)malloc(sizeof(bitree));s->data=ch;s->lchild=NULL;s->rchild=NULL;} rear++;Q[rear]=s;//将虚结点指针NULL或新结点地址入队 if(rear==1)root=s;//输入第一个结点为根结点 else 金陵科技学院实验报告 {if(s&&Q[front])//孩子和双亲结点均不是虚结点 if(rear%2==0)Q[front]->lchild=s;//rear为偶数,新结点是左孩子 else Q[front]->rchild=s;//结点*Q[front]的两个孩子已处理完毕,出队列 if(rear%2==1)front++;} ch=getchar();// } return root;//} //求二叉树的节点的总数 int sum(bitree *T){ int num1,num2;if(T==NULL)return 0;else if(T->lchild==NULL&&T->rchild==NULL)return 1;else { num1=sum(T->lchild);num2=sum(T->rchild);return(num1+num2+1);} } main(){int m; 输入下一个字符 返回头指针 金陵科技学院实验报告 bitree *L;printf(“建立的二叉树为:n”);L=creattree();m=sum(L);printf(“二叉树的结点总数为:n”);printf(“%d”,m);getchar();getchar();} 4. #include //二叉树的建立函数 bitree *creattree()//{bitree *Q[maxsize];// char ch;int front,rear;// bitree *root,*s;root=NULL;// front=1;rear=0;// ch=getchar();// while(ch!='n')//建立二叉树,函数返回指向根的指针队列Q为bitree指针类型的数组 队头队尾指针 置空二叉树 置空队列 输入第一个字符 不是结束符的时候重复做 金陵科技学院实验报告 { s=NULL;if(ch!='@')//空格表示虚结点,不是虚结点时建立新的结点 { s=(bitree*)malloc(sizeof(bitree));s->data=ch;s->lchild=NULL;s->rchild=NULL;} rear++;Q[rear]=s;//新结点地址入队 if(rear==1)root=s;//结点 else {if(s&&Q[front])//是虚结点 if(rear%2==0)Q[front]->lchild=s;//rear是左孩子 else Q[front]->rchild=s;//孩子已处理完毕,出队列 if(rear%2==1)front++;} ch=getchar();// } return root;//} 将虚结点指针NULL或输入第一个结点为根孩子和双亲结点均不为偶数,新结点结点*Q[front]的两个输入下一个字符 返回头指针 金陵科技学院实验报告 //二叉树的深度函数 int high(bitree *T){int m,n;if(T==NULL)return 0;else m=high(T->lchild);n=high(T->rchild);return((m>n?m:n)+1);} //主函数 main(){int m;bitree *L;printf(“建立的二叉树为:n”);L=creattree();m=high(L);printf(“二叉树的高度为:n”);printf(“%d”,m);getchar();getchar();} 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析)1. 2.金陵科技学院实验报告 3.。 4.。 五、实验体会(遇到问题及解决办法,编程后的心得体会) 树是常用的数据结构。通过实验加深了我对树的遍历的认识,巩固了课本中所学的关于树的基本算法。按要求完成了实验内容。通过实验,有如下几点收获和体会: 1、通过实验还提高了一点改错能力,对于一些常见问题加深了印象。 2、编程需要细心,有时一个不注意小错误就能引出大问题。编程也需要规范,不仅为了他人能看得懂程序,也为了方便自己以后程序的更改与进一步的完善。 3、程序由算法和数据结构组成,一个好的程序不仅算法重要,数据结构的设计也很重要。4.二叉树的先序、中序与后序的输出都用了递归算法。而且用起来并不复杂,这使我更进一步学习理解了函数的递归调用并得到灵活的运用。经过本次实验基本上解决的一些所遇到的问题,我对二叉树的结构等有了较为深入的理解。我会继续我的兴趣编写程序的,相信在越来越多的尝试之后,自己会不断进步。 金陵科技学院实验报告 实验项目名称: 图 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验6 图 一、实验目的和要求 (1)熟练掌握图的基本概念、构造及其存储结构。 (2)熟练掌握对图的深度优先搜索遍历和广度优先搜索遍历的算法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)构造一个无向图(用邻接矩阵表示存储结构)。 (2)对上面所构造的无向图,进行深度优先遍历和广度优先遍历,输出遍历序列。 2、选做题 采用邻接表存储结构,编写一个判别无向图中任意给定的两个顶点之间是否存在一条长度为k的简单路径的算法。简单路径是指其顶点序列中不含有重复顶点的路径。提示:两个顶点及k值均作为参数给出。程序清单: (1)#include void GraphInit(GRAPH *L){ L->num=0;} int GraphVexs(GRAPH *L){ return(L->num);} 金陵科技学院实验报告 void GraphCreate(GRAPH *L){ int i,j;GraphInit(L);printf(“请输入顶点数目:n”);scanf(“%d”,&L->num);printf(“请输入各顶点的信息:n”);for(i=0;i fflush(stdin); scanf(“%c”,&L->vexs[i]);} printf(“请输入边权矩阵的信息:n”);for(i=0;i for(j=0;j { scanf(“%d”,&L->arcs[i][j]); } } printf(“图已经创建完毕!”);} void GraphOut(GRAPH L){ int i,j;printf(“n图的顶点数目为:%d”,L.num);printf(“n图的各顶点的信息为:n”);for(i=0;i for(j=0;j { printf(“%6d”,L.arcs[i][j]); } printf(“n”);} printf(“图已经输出完毕!”);} void main(){ GRAPH tu;GraphCreate(&tu);GraphOut(tu);system(“pause”);getchar();}(2)#include 金陵科技学院实验报告 #define n 100 typedef char VEXTYPE;typedef int ADJTYPE;typedef struct { VEXTYPE vexs[n];ADJTYPE arcs[n][n];int num;}GRAPH; void GraphInit(GRAPH *L){ L->num=0;} int GraphVexs(GRAPH *L){ return(L->num);} void GraphCreate(GRAPH *L){ int i,j;GraphInit(L);printf(“请输入顶点数目:n”);scanf(“%d”,&L->num);printf(“请输入各顶点的信息:n”);for(i=0;i fflush(stdin); scanf(“%c”,&L->vexs[i]);} printf(“请输入边权矩阵的信息:n”);for(i=0;i for(j=0;j { scanf(“%d”,&L->arcs[i][j]); } } printf(“图已经创建完毕!”);} void GraphOut(GRAPH L){ int i,j;printf(“n图的顶点数目为:%d”,L.num);printf(“n图的各顶点的信息为:n”);for(i=0;i for(j=0;j { printf(“%6d”,L.arcs[i][j]); } 金陵科技学院实验报告 printf(“n”);} printf(“图已经输出完毕!”);} void DFS(GRAPH g,int qidian,int mark[]){ int v1;mark[qidian]=1;printf(“%6c”,g.vexs[qidian]);for(v1=0;v1 mark[v]=0;} for(v=qidian;v v1=v%g.num; if(mark[v1]==0) DFS(g,v1,mark);} } typedef int DATATYPE;typedef struct { DATATYPE data[maxsize];int front,rear;} SEQQUEUE;void QueueInit(SEQQUEUE *sq){ sq->front=0;sq->rear=0;} int QueueIsEmpty(SEQQUEUE sq){ if(sq.rear==sq.front)return(1);else return(0);} int QueueFront(SEQQUEUE sq,DATATYPE *e){ if(QueueIsEmpty(sq)){ printf(“queue is empty!n”); return 0;} 金陵科技学院实验报告 else { *e=sq.data[(sq.front)]; return 1;} } int QueueIn(SEQQUEUE *sq,DATATYPE x){ if(sq->front==(sq->rear+1)%maxsize){ printf(“queue is full!n”); return 0;} else { sq->data[sq->rear]=x; sq->rear=(sq->rear+1)%maxsize; return(1);} } int QueueOut(SEQQUEUE *sq){ if(QueueIsEmpty(*sq)){ printf(“queue is empty!n”); return 0;} else { sq->front=(sq->front+1)%maxsize; return 1;} } void BFS(GRAPH g,int v,int mark[]){ int v1,v2;SEQQUEUE q;QueueInit(&q);QueueIn(&q,v);mark[v]=1;printf(“%6c”,g.vexs[v]);while(QueueIsEmpty(q)==0){ QueueFront(q,&v1); QueueOut(&q); for(v2=0;v2 { if(g.arcs[v1][v2]!=0&&mark[v2]==0) { QueueIn(&q,v2); mark[v2]=1; printf(“%6c”,g.vexs[v2]); } } } } void GraphBFS(GRAPH g){ 金陵科技学院实验报告 int qidian,v,v1,mark[maxsize];printf(“n广度优先遍历:”);printf(“n请输入起点的下标:”);scanf(“%d”,&qidian);for(v=0;v mark[v]=0;} for(v=qidian;v v1=v%g.num; if(mark[v1]==0) BFS(g,v1,mark);} } void main(){ GRAPH tu;GraphCreate(&tu);GraphOut(tu);GraphDFS(tu);GraphBFS(tu);system(“pause”);getchar();} 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 1.金陵科技学院实验报告 2.五、实验体会(遇到问题及解决办法,编程后的心得体会) 这次的图的操作实验,与树的操作类似,但又比树复杂,包含更多的存储结构和遍历方法的操作,而且图的遍历需要沿着弧进行,以便输出弧上的信息。本实验中图的亢奋采用邻接表的存储结构,在输入图的信息时,首先要画出图的邻接表信息。图有两种遍历的形式,一种为深度优先搜索,一种为广度优先搜索。由于能力有限,没有能实现图的深度非递归优先搜索。本次实验基本完成了图的操作,也学到了很多关于图的知识和算法。 金陵科技学院实验报告 实验项目名称: 排序 实验学时: 2 同组学生姓名: ╱ 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 学 生 实 验 报 告 册 课程名称: 学生学号: 所属院部: (理工类) 算法与数据结构 专业班级: 14计单(2) 1413201007 学生姓名: 毛卓 计算机工程学院 指导教师: 章海鸥 16 ——20 17 学年 第 二 学期 金陵科技学院教务处制 金陵科技学院实验报告 实验报告书写要求 实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。 实验报告书写说明 实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。 填写注意事项 (1)细致观察,及时、准确、如实记录。(2)准确说明,层次清晰。 (3)尽量采用专用术语来说明事物。 (4)外文、符号、公式要准确,应使用统一规定的名词和符号。(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。 实验报告批改说明 实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。 实验报告装订要求 实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。 金陵科技学院实验报告 实验项目名称: 顺序表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验1 顺序表 一、实验目的和要求 掌握顺序表的定位、插入、删除等操作。 二、实验仪器和设备 VC6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。编写主函数测试结果。 (2)编写顺序表定位操作子函数,在顺序表中查找是否存在数据元素x。如果存在,返回顺序表中和x值相等的第1个数据元素的序号(序号从0开始编号);如果不存在,返回-1。编写主函数测试结果。(3)在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。 解题思路:首先查找插入的位置,再移位,最后进行插入操作;从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置;然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。 (4)删除顺序表中所有等于X的数据元素。 2、选做题 (5)已知两个顺序表A和B按元素值递增有序排列,要求写一算法实现将A和B归并成一个按元素值递减有序排列的顺序表(允许表中含有值相同的元素)。 程序清单: (1):/*编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。*/ #include 金陵科技学院实验报告 }sequenlist;void main(){ sequenlist L;int i,n;printf(“请输入元素个数:”);scanf(“%d”,&n);printf(“n请输入元素:”);for(i=0;i 如果不存在,返回-1。*/ #include int fun(sequenlist L,int x,int n){ 金陵科技学院实验报告 } int i;for(i=0;i } int i,n,y;int x; printf(“请输入元素个数:”);scanf(“%d”,&n);printf(“n请输入元素:”);for(i=0;i printf(“n请输入要查找的数据元素:”);scanf(“%d”,&x);y=fun(L,x,n);if(y==-1)else printf(“n数据元素 %d 所在的位置为 %d n”,x,y);printf(“n所要查找的数据元素不存在。n”);(3): /*在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。 解题思路:首先查找插入的位置,再移位,最后进行插入操作; 从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置; 金陵科技学院实验报告 然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。*/ #define maxsize 100 typedef struct{ int data[maxsize]; int last;}sequenlist;main(){ int i,x,j; sequenlist l={{1,3,5,6,7,9},5}; printf(“n插入元素前的数据为:”); for(i=0;i<=l.last;i++) printf(“%2d”,l.data[i]); printf(“n请输入要插入的元素:”); scanf(“%d”,&x); for(i=1;i<=l.last;i++) if(l.data[i-1]>x)break; if(i>l.last) { l.data [l.last +1]=x; } else { for(j=l.last;j>=i-1;j--)l.data[j+1]=l.data[j];l.data[i-1]=x; } l.last++; printf(“插入元素后的数据为:n”); 金陵科技学院实验报告 for(j=0;j<=l.last;j++) printf(“%3d”,l.data[j]); printf(“n”);}(4): /*删除顺序表中所有等于X的数据元素。*/ #define maxsize 100 typedef struct{ int data[maxsize]; int last;}sequenlist;main(){ int i,j,x=0,k=0; sequenlist L={{1,3,5,7,2,4,6,8,2,9},9}; printf(“n原数据为:”); for(i=0;i<=L.last;i++)printf(“%3d”,L.data[i]); printf(“n请输入要删除的数据:”); scanf(“%d”,&x); for(i=1;i<=L.last+1;i++) if(L.data[i-1]==x){ for(j=i;j<=L.last+1;j++)L.data[j-1]=L.data[j]; L.last--; i--; k=1; } if(k==1){ printf(“删除后的数据为:n”); for(j=0;j<=L.last;j++)printf(“%3d”,L.data[j]); } else printf(“Not found!n”); 金陵科技学院实验报告 printf(“n”);} 四、实验结果与分析(程序运行结果及其分析)(1)结果: 请输入元素个数:5 请输入元素:1 2 3 4 5 元素输出:1 2 3 4 5(2)结果: 请输入元素个数:5 请输入元素:1 2 3 4 5 请输入要查找的数据元素:5 数据元素5所在的位置为 4(3)结果:插入数据前的元素为:1 3 5 6 7 9 请输入要插入的元素为:10 插入元素后的数据为: 5 6 7 9 10(4)结果:原数据为:1 3 5 7 2 4 6 8 2 9 请输入要删除的数据为:7 删除后的数据为: 3 5 2 4 6 8 2 9 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 单链表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验2 单链表 一、实验目的和要求 1、实验目的 掌握单链表的定位、插入、删除等操作。 2、实验要求 (1)注意链表的空间是动态分配的,某结点不用之后要及时进行物理删除,以便释放其内存空间。 (2)链表不能实现直接定位,一定注意指针的保存,防止丢失。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个单链表,并逐个输出单链表中所有数据元素。(2)在递增有序的单链表中插入一个新结点x,保持单链表的有序性。 解题思路:首先查找插入的位置然后进行插入操作;从第一个结点开始找到第一个大于该新结点值的结点即为插入位置;然后在找到的此结点之前插入新结点;注意保留插入位置之前结点的指针才能完成插入操作。 (3)编写实现带头结点单链表就地逆置的子函数,并编写主函数测试结果。 2、选做题 已知指针LA和LB分别指向两个无头结点单链表的首元结点。要求编一算法实现,从表LA中删除自第i个元素起共len个元素后,将它们插入到表LB中第j个元素之前。程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 堆栈和队列 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验3 堆栈和队列 一、实验目的和要求 (1)掌握应用栈解决问题的方法。(2)掌握利用栈进行表达式求和的算法。 (3)掌握队列的存储结构及基本操作实现,并能在相应的应用问题中正确选用它们。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)判断一个算术表达式中开括号和闭括号是否配对。(2)测试“汉诺塔”问题。 (3)假设称正读和反读都相同的字符序列为”回文”,试写一个算法判别读入的一个以’@’为结束符的字符序列是否是“回文”。 2、选做题 在顺序存储结构上实现输出受限的双端循环队列的入列和出列算法。设每个元素表示一个待处理的作业,元素值表示作业的预计时间。入队列采取简化的短作业优先原则,若一个新提交的作业的预计执行时间小于队头和队尾作业的平均时间,则插入在队头,否则插入在队尾。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 串 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验4 串 一、实验目的和要求 掌握串的存储及应用。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写输出字符串s中值等于字符ch的第一个字符的函数,并用主函数测试结果。 (2)编写输出字符串s中值等于字符ch的所有字符的函数,并用主函数测试结果。 解题思路:可以将第一题程序改进成一个子函数,在本题中循环调用。(3)设字符串采用单字符的链式存储结构,编程删除串s从位置i开始长度为k的子串。 2、选做题 假设以链结构表示串,编写算法实现将串S插入到串T中某个字符之后,若串T中不存在这个字符,则将串S联接在串T的末尾。 提示:为提高程序的通用性,插入位置字符应设计为从键盘输入。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 二叉树 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验5 二叉树 一、实验目的和要求 (1)掌握二叉树的生成,以及前、中、后序遍历算法。(2)掌握应用二叉树递归遍历思想解决问题的方法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)建立一棵二叉树。对此树进行前序遍历、中序遍历及后序遍历,输出遍历序列。 (2)在第一题基础上,求二叉树中叶结点的个数。(3)在第一题基础上,求二叉树中结点总数。(4)在第一题基础上,求二叉树的深度。 2、选做题 已知一棵完全二叉树存于顺序表sa中,sa.elem[1…sa.last]存储结点的值。试编写算法由此顺序存储结构建立该二叉树的二叉链表。 解题思路:根据完全二叉树顺序存储的性质来确定二叉树的父子关系即“还原”了二叉树,之后再按照二叉树二叉链表的构造方法进行建立。完全二叉树顺序存储的一个重要性质为,第i个结点的左孩子是编号为2i的结点,第i个结点的右孩子是编号为2i+1的结点。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 图 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验6 图 一、实验目的和要求 (1)熟练掌握图的基本概念、构造及其存储结构。 (2)熟练掌握对图的深度优先搜索遍历和广度优先搜索遍历的算法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)构造一个无向图(用邻接矩阵表示存储结构)。 (2)对上面所构造的无向图,进行深度优先遍历和广度优先遍历,输出遍历序列。 2、选做题 采用邻接表存储结构,编写一个判别无向图中任意给定的两个顶点之间是否存在一条长度为k的简单路径的算法。简单路径是指其顶点序列中不含有重复顶点的路径。提示:两个顶点及k值均作为参数给出。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 排序 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验7 排序 一、实验目的和要求 (1)熟练掌握希尔排序、堆排序、直接插入排序、起泡排序、快速排序、直接选择排序、归并排序和基数排序的基本概念。 (2)掌握以上各种排序的算法。区分以上不同排序的优、缺点。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 用随机数产生100000个待排序数据元素的关键字值。测试下列各排序函数的机器实际执行时间(至少测试两个):直接插入排序、希尔排序(增量为4,2,1)、冒泡排序、快速排序、直接选择排序、二路归并排序、堆排序和基于链式队列的基数排序。 2、选做题 假设含n个记录的序列中,其所有关键字为值介于v和w之间的整数,且其中很多关键字的值是相同的。则可按如下方法排序:另设数组number[v…w],令number[i]统计关键字为整数i的纪录个数,然后按number重排序列以达到有序。试编写算法实现上述排序方法,并讨论此种方法的优缺点。程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 查找 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验8 查找 一、实验目的和要求 (1)掌握顺序表查找、有序表查找、索引顺序表查找的各种算法。(2)掌握哈希表设计。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)在一个递增有序的线性表中利用二分查找法查找数据元素X。 2、选做题 (2)构造一个哈希表,哈希函数采用除留余数法,哈希冲突解决方法采用链地址法。设计一个测试程序进行测试。 提示:构造哈希表只是完成查找的第一步,大家应该掌握在哈希表上进行查找的过程,可以试着编程序实现。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 学 生 实 验 报 告 册 课程名称: 学生学号: 所属院部: (理工类) 算法与数据结构 专业班级: 学生姓名: 指导教师: 14 ——20 15 学年 第 二 学期 金陵科技学院教务处制 金陵科技学院实验报告 实验报告书写要求 实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。 实验报告书写说明 实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。 填写注意事项 (1)细致观察,及时、准确、如实记录。(2)准确说明,层次清晰。 (3)尽量采用专用术语来说明事物。 (4)外文、符号、公式要准确,应使用统一规定的名词和符号。(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。 实验报告批改说明 实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。 实验报告装订要求 实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。 金陵科技学院实验报告 实验项目名称: 顺序表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验1 顺序表 一、实验目的和要求 掌握顺序表的定位、插入、删除等操作。 二、实验仪器和设备 Turbo C 2.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。编写主函数测试结果。 (2)编写顺序表定位操作子函数,在顺序表中查找是否存在数据元素x。如果存在,返回顺序表中和x值相等的第1个数据元素的序号(序号从0开始编号);如果不存在,返回-1。编写主函数测试结果。(3)在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。 解题思路:首先查找插入的位置,再移位,最后进行插入操作;从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置;然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。 (4)删除顺序表中所有等于X的数据元素。 2、选做题 (5)已知两个顺序表A和B按元素值递增有序排列,要求写一算法实现将A和B归并成一个按元素值递减有序排列的顺序表(允许表中含有值相同的元素)。 程序清单: 1、(1)#include datatype a[maxsize]; int size;}sequence_list;sequence_list mylist;void display(sequence_list slt) 金陵科技学院实验报告 { int i; if(slt.size==0) printf(“n 顺表表是空的”); else for(i=0;i printf(“%5d”,slt.a[i]);} void init(sequence_list *slt){ slt->size=0;} void main(){ int i,number;init(&mylist);printf(“顺序表是空的请建立顺序表!”);printf(“n”);printf(“请输入顺序表中的元素个数!n”);scanf(“%d”,&number);mylist.size=number;for(i=0;i scanf(“%d”,&mylist.a[i]);} }(2)#include datatype a[maxsize]; int size;}sequence_list;sequence_list mylist;void display(sequence_list slt){ int i;display(mylist);printf(“n”); 金陵科技学院实验报告 if(slt.size==0) printf(“n 顺表表是空的”); else for(i=0;i printf(“%5d”,slt.a[i]);} void init(sequence_list *slt){ slt->size=0;} int find(sequence_list *slt,int x){ int i,a;for(i=0;i if(x==slt->a[i]) { a=i; break; } } if(i!=slt->size) return a; else return-1;} void main(){ int i,number,a,b;init(&mylist);printf(“顺序表是空的请建立顺序表!”);printf(“n”);printf(“请输入顺序表中的元素个数!n”);scanf(“%d”,&number);mylist.size=number;for(i=0;i scanf(“%d”,&mylist.a[i]);} display(mylist);printf(“n”);printf(“输入要查找的数:”);scanf(“%d”,&a);b=find(&mylist,a); 金陵科技学院实验报告 } if(b!=-1){ printf(“顺序表的下标为:%dn”,b);} else printf(“can not be found!”);(3)#include for(i=0;i for(j=i+1;j { if(slt->a[i]>slt->a[j]) { temp=slt->a[i]; slt->a[i]=slt->a[j]; 金陵科技学院实验报告 slt->a[j]=temp; } } } } void append(sequence_list *slt,int x){ slt->a[slt->size]=x;slt->size++;sort(&mylist);} void main(){ int i,number,x;init(&mylist);printf(“顺序表是空的请建立顺序表!”);printf(“n”);printf(“请输入顺序表中的元素个数!n”);scanf(“%d”,&number);mylist.size=number;for(i=0;i scanf(“%d”,&mylist.a[i]);} display(mylist);sort(&mylist);printf(“n”);display(mylist);printf(“n”);printf(“输入要插入的元素:”);printf(“n”);scanf(“%d”,&x);append(&mylist,x);display(mylist);printf(“n”);}(4)#include typedef int datatype;typedef struct 金陵科技学院实验报告 { datatype a[maxsize];int size;}sequence_list;sequence_list mylist;void display(sequence_list slt){ int i;if(slt.size == 0) printf(“n 顺表表是空的”);else for(i = 0;i printf(“%5d”, slt.a[i]);} void init(sequence_list *slt){ slt->size = 0;} void sort(sequence_list *slt){ int i, j, temp;//交换法排序 for(i = 0;i for(j = i + 1;j { if(slt->a[i]>slt->a[j]) { temp = slt->a[i]; slt->a[i] = slt->a[j]; slt->a[j] = temp; } } } } void del(sequence_list *slt, int x){ int m[maxsize];int i, n = 0, j, a = 0;for(i = 0;i if(slt->a[i]!= x) { 金陵科技学院实验报告 m[n++] = slt->a[i]; } else a++; } slt->size = slt->size1, from, to, denpend_on);//先将初始塔的前n-1个盘子借助目的塔移动到借用塔上 move(n, from, to);//将剩下的一个盘子移动到目的塔上 hanoi(n1);} int IsPalindrome(char * str){ int len = StrLen(str);int i = 0;for(;i if(str[i]!= str[len1])return 0;} return 1;} void main(){ char * str =(char *)malloc(INIT_SIZE * sizeof(char));char ch;int i = 0;//字符串当前字符数 int len = INIT_SIZE;//字符串空间大小 while(ch = getchar()){ // 循环录入字符串 if(ch == '@'){ ///如果按回车键,则结束 str[i] = ' ';///字符串结束标志 break; } 金陵科技学院实验报告 if(i < len-1){ str[i] = ch; } else { str =(char *)realloc(str,(len + INCR_SIZE)* sizeof(char));//增加存储空间 str[i] = ch; len += INCR_SIZE;//重新记录字符串空间 } i++;} if(IsPalindrome(str)!= 0){ printf(“YESn”);} else { printf(“NOn”);} } 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析)(1) (2) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 通过该实验我熟练掌握了如何通过堆栈和队列来判断一个算术表达式中开括号和闭括号是否配对,测试“汉诺塔”问题以及判断回文数。 金陵科技学院实验报告 实验项目名称: 串 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验4 串 一、实验目的和要求 掌握串的存储及应用。 二、实验仪器和设备 Turbo C 2.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写输出字符串s中值等于字符ch的第一个字符的函数,并用主函数测试结果。 (2)编写输出字符串s中值等于字符ch的所有字符的函数,并用主函数测试结果。 解题思路:可以将第一题程序改进成一个子函数,在本题中循环调用。(3)设字符串采用单字符的链式存储结构,编程删除串s从位置i开始长度为k的子串。 2、选做题 假设以链结构表示串,编写算法实现将串S插入到串T中某个字符之后,若串T中不存在这个字符,则将串S联接在串T的末尾。 提示:为提高程序的通用性,插入位置字符应设计为从键盘输入。程序清单: (1)#include if(ch==s[i]) { c=s[i]; 金陵科技学院实验报告 } } } if(s[i]){ printf(“输出字符:”);putchar(c);printf(“n”);} else { printf(“没有找到!”);}(2)#include for(i=0;s[i]!=' ';i++){ if(ch==s[i]) { c=s[i]; j++; } } if((i-1)!=strlen(s)){ printf(“有%d个元素”,j);printf(“n”);printf(“输出字符:”);putchar(c);printf(“n”);} else { 金陵科技学院实验报告 printf(“没有找到!”);} } void main(){ char s[100],ch;int i;printf(“创建字符串!”);gets(s);printf(“输入要查找的字符:”);scanf(“%c”,&ch);find(s,ch);}(3)#include p = malloc(sizeof(linkstring)); p->data = ch; 金陵科技学院实验报告 if(S == NULL)S = p, q = p; else q->next = p, q = p; ch = getchar();} if(q->next!= NULL)q->next = NULL;return S;} linkstring *Delete(linkstring *S, int i, int k)//足够长 { linkstring *p = S, *q;int m = 2;while(m p = p->next; m++;} m = 0;if(i == 1)while(m 假定字符串金陵科技学院实验报告 S = p->next; free(p); p = S; m++;} else while(m q = p->next; p->next = q->next; free(q); m++;} return S;} void Output(linkstring *S){ linkstring *p = S;while(p!= NULL){ printf(“%2c”, p->data); p = p->next; 金陵科技学院实验报告 } } int main(){ linkstring *S = NULL;int i, k;S = Creatlink(S);Output(S);printf(“n”);printf(“Please enter the location and the length:”);scanf(“%d%d”, &i, &k);S = Delete(S, i, k);getchar();Output(S);printf(“n”);return 0;} 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会)通过该实验我熟练掌握了如何建立一个串,如何查找串中的元素以及 金陵科技学院实验报告 删除指定的子串。 金陵科技学院实验报告 实验项目名称: 二叉树 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验5 二叉树 一、实验目的和要求 (1)掌握二叉树的生成,以及前、中、后序遍历算法。(2)掌握应用二叉树递归遍历思想解决问题的方法。 二、实验仪器和设备 Turbo C 2.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)建立一棵二叉树。对此树进行前序遍历、中序遍历及后序遍历,输出遍历序列。 (2)在第一题基础上,求二叉树中叶结点的个数。(3)在第一题基础上,求二叉树中结点总数。(4)在第一题基础上,求二叉树的深度。 2、选做题 已知一棵完全二叉树存于顺序表sa中,sa.elem[1…sa.last]存储结点的值。试编写算法由此顺序存储结构建立该二叉树的二叉链表。 解题思路:根据完全二叉树顺序存储的性质来确定二叉树的父子关系即“还原”了二叉树,之后再按照二叉树二叉链表的构造方法进行建立。完全二叉树顺序存储的一个重要性质为,第i个结点的左孩子是编号为2i的结点,第i个结点的右孩子是编号为2i+1的结点。程序清单: (1)#include int TWOCHILD;//有两个孩子的结点数 int LEAF;//叶子数 int NODE;//结点数 using namespace std;typedef struct binode{ int data;struct binode *lchild,*rchild;}binode,*bitree; 金陵科技学院实验报告 typedef struct{ bitree elem[100];int top;}stack; bitree creat_bt(){ //按扩展前序建二叉树 bitree t;int x;scanf(“%d”,&x);if(x==0)t=NULL;//以0作为结束 else { t=(bitree)malloc(sizeof(binode));t->data=x;printf(“请输入%d结点的左孩子结点(若没有,请输入 0)”,t->data);t->lchild=creat_bt();printf(“请输入%d结点的右孩子结点(若没有,请输入 0)”,t->data);t->rchild=creat_bt();} return t;} void preorder(bitree t){ if(t){ printf(“%dn”,t->data);preorder(t->lchild);preorder(t->rchild);} } void inorder(bitree t){ if(t){ inorder(t->lchild);printf(“%dn”,t->data);inorder(t->rchild);} } void postorder(bitree t){ if(t){ postorder(t->lchild); 金陵科技学院实验报告 学 生 实 验 报 告 册 课程名称: 学生学号: 所属院部: (理工类) 算法与数据结构 专业班级: 学生姓名: 指导教师: ——20 学年 第 学期 金陵科技学院教务处制 金陵科技学院实验报告 实验报告书写要求 实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。 实验报告书写说明 实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。 填写注意事项 (1)细致观察,及时、准确、如实记录。(2)准确说明,层次清晰。 (3)尽量采用专用术语来说明事物。 (4)外文、符号、公式要准确,应使用统一规定的名词和符号。(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。 实验报告批改说明 实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。 实验报告装订要求 实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。 金陵科技学院实验报告 实验项目名称: 顺序表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验1 顺序表 一、实验目的和要求 掌握顺序表的定位、插入、删除等操作。 二、实验仪器和设备 VC6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。编写主函数测试结果。 (2)编写顺序表定位操作子函数,在顺序表中查找是否存在数据元素x。如果存在,返回顺序表中和x值相等的第1个数据元素的序号(序号从0开始编号);如果不存在,返回-1。编写主函数测试结果。(3)在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。 解题思路:首先查找插入的位置,再移位,最后进行插入操作;从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置;然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。 (4)删除顺序表中所有等于X的数据元素。 2、选做题 (5)已知两个顺序表A和B按元素值递增有序排列,要求写一算法实现将A和B归并成一个按元素值递减有序排列的顺序表(允许表中含有值相同的元素)。 程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 单链表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验2 单链表 一、实验目的和要求 1、实验目的 掌握单链表的定位、插入、删除等操作。 2、实验要求 (1)注意链表的空间是动态分配的,某结点不用之后要及时进行物理删除,以便释放其内存空间。 (2)链表不能实现直接定位,一定注意指针的保存,防止丢失。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个单链表,并逐个输出单链表中所有数据元素。(2)在递增有序的单链表中插入一个新结点x,保持单链表的有序性。 解题思路:首先查找插入的位置然后进行插入操作;从第一个结点开始找到第一个大于该新结点值的结点即为插入位置;然后在找到的此结点之前插入新结点;注意保留插入位置之前结点的指针才能完成插入操作。 (3)编写实现带头结点单链表就地逆置的子函数,并编写主函数测试结果。 2、选做题 已知指针LA和LB分别指向两个无头结点单链表的首元结点。要求编一算法实现,从表LA中删除自第i个元素起共len个元素后,将它们插入到表LB中第j个元素之前。程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 堆栈和队列 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验3 堆栈和队列 一、实验目的和要求 (1)掌握应用栈解决问题的方法。(2)掌握利用栈进行表达式求和的算法。 (3)掌握队列的存储结构及基本操作实现,并能在相应的应用问题中正确选用它们。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)判断一个算术表达式中开括号和闭括号是否配对。(2)测试“汉诺塔”问题。 (3)假设称正读和反读都相同的字符序列为”回文”,试写一个算法判别读入的一个以’@’为结束符的字符序列是否是“回文”。 2、选做题 在顺序存储结构上实现输出受限的双端循环队列的入列和出列算法。设每个元素表示一个待处理的作业,元素值表示作业的预计时间。入队列采取简化的短作业优先原则,若一个新提交的作业的预计执行时间小于队头和队尾作业的平均时间,则插入在队头,否则插入在队尾。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 串 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验4 串 一、实验目的和要求 掌握串的存储及应用。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写输出字符串s中值等于字符ch的第一个字符的函数,并用主函数测试结果。 (2)编写输出字符串s中值等于字符ch的所有字符的函数,并用主函数测试结果。 解题思路:可以将第一题程序改进成一个子函数,在本题中循环调用。(3)设字符串采用单字符的链式存储结构,编程删除串s从位置i开始长度为k的子串。 2、选做题 假设以链结构表示串,编写算法实现将串S插入到串T中某个字符之后,若串T中不存在这个字符,则将串S联接在串T的末尾。 提示:为提高程序的通用性,插入位置字符应设计为从键盘输入。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 二叉树 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验5 二叉树 一、实验目的和要求 (1)掌握二叉树的生成,以及前、中、后序遍历算法。(2)掌握应用二叉树递归遍历思想解决问题的方法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)建立一棵二叉树。对此树进行前序遍历、中序遍历及后序遍历,输出遍历序列。 (2)在第一题基础上,求二叉树中叶结点的个数。(3)在第一题基础上,求二叉树中结点总数。(4)在第一题基础上,求二叉树的深度。 2、选做题 已知一棵完全二叉树存于顺序表sa中,sa.elem[1…sa.last]存储结点的值。试编写算法由此顺序存储结构建立该二叉树的二叉链表。 解题思路:根据完全二叉树顺序存储的性质来确定二叉树的父子关系即“还原”了二叉树,之后再按照二叉树二叉链表的构造方法进行建立。完全二叉树顺序存储的一个重要性质为,第i个结点的左孩子是编号为2i的结点,第i个结点的右孩子是编号为2i+1的结点。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 图 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验6 图 一、实验目的和要求 (1)熟练掌握图的基本概念、构造及其存储结构。 (2)熟练掌握对图的深度优先搜索遍历和广度优先搜索遍历的算法。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)构造一个无向图(用邻接矩阵表示存储结构)。 (2)对上面所构造的无向图,进行深度优先遍历和广度优先遍历,输出遍历序列。 2、选做题 采用邻接表存储结构,编写一个判别无向图中任意给定的两个顶点之间是否存在一条长度为k的简单路径的算法。简单路径是指其顶点序列中不含有重复顶点的路径。提示:两个顶点及k值均作为参数给出。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 排序 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验7 排序 一、实验目的和要求 (1)熟练掌握希尔排序、堆排序、直接插入排序、起泡排序、快速排序、直接选择排序、归并排序和基数排序的基本概念。 (2)掌握以上各种排序的算法。区分以上不同排序的优、缺点。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 用随机数产生100000个待排序数据元素的关键字值。测试下列各排序函数的机器实际执行时间(至少测试两个):直接插入排序、希尔排序(增量为4,2,1)、冒泡排序、快速排序、直接选择排序、二路归并排序、堆排序和基于链式队列的基数排序。 2、选做题 假设含n个记录的序列中,其所有关键字为值介于v和w之间的整数,且其中很多关键字的值是相同的。则可按如下方法排序:另设数组number[v…w],令number[i]统计关键字为整数i的纪录个数,然后按number重排序列以达到有序。试编写算法实现上述排序方法,并讨论此种方法的优缺点。程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 查找 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验8 查找 一、实验目的和要求 (1)掌握顺序表查找、有序表查找、索引顺序表查找的各种算法。(2)掌握哈希表设计。 二、实验仪器和设备 Visual C++6.0 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)在一个递增有序的线性表中利用二分查找法查找数据元素X。 2、选做题 (2)构造一个哈希表,哈希函数采用除留余数法,哈希冲突解决方法采用链地址法。设计一个测试程序进行测试。 提示:构造哈希表只是完成查找的第一步,大家应该掌握在哈希表上进行查找的过程,可以试着编程序实现。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 学 生 实 验 报 告 册 课程名称: 学生学号: 所属院部: (理工类) 算法与数据结构 专业班级: 13网络工程 1305106009 学生姓名: 陈韬 网络与通信工程学院 指导教师: 沈奇 14 ——20 15 学年 第 1 学期 金陵科技学院教务处制 金陵科技学院实验报告 实验报告书写要求 实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。 实验报告书写说明 实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。 填写注意事项 (1)细致观察,及时、准确、如实记录。(2)准确说明,层次清晰。 (3)尽量采用专用术语来说明事物。 (4)外文、符号、公式要准确,应使用统一规定的名词和符号。(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。 实验报告批改说明 实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。 实验报告装订要求 实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。 金陵科技学院实验报告 实验项目名称: 顺序表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验1 顺序表 一、实验目的和要求 掌握顺序表的定位、插入、删除等操作。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个顺序表,并逐个输出顺序表中所有数据元素的值。编写主函数测试结果。 (2)编写顺序表定位操作子函数,在顺序表中查找是否存在数据元素x。如果存在,返回顺序表中和x值相等的第1个数据元素的序号(序号从0开始编号);如果不存在,返回-1。编写主函数测试结果。(3)在递增有序的顺序表中插入一个新结点x,保持顺序表的有序性。 解题思路:首先查找插入的位置,再移位,最后进行插入操作;从第一个元素开始找到第一个大于该新结点值x的元素位置i即为插入位置;然后将从表尾开始依次将元素后移一个位置直至元素i;最后将新结点x插入到i位置。 (4)删除顺序表中所有等于X的数据元素。 2、选做题 (5)已知两个顺序表A和B按元素值递增有序排列,要求写一算法实现将A和B归并成一个按元素值递减有序排列的顺序表(允许表中含有值相同的元素)。 程序清单: #include 金陵科技学院实验报告 } sequenlist;sequenlist L={{1,3,5,5,7,8,10,12,17},8};void print_list(){ int i;for(i=0;i<=L.last;i++)printf(“%4d”,L.data[i]);} void find_all_x(int x){ int found=0,i;for(i=0;i<=L.last;i++)if(L.data[i]==x){ printf(“%3d”,i+1);found=1;} if(found==0)printf(“-1n”);} void insert_x(int x){ int loc,i;for(i=0;i<=L.last;i++)if(x 金陵科技学院实验报告 loc=i;for(i=L.last;i>=loc;i--)L.data[i+1]=L.data[i];L.data[loc]=x;L.last++;} void delete_x(int x){ int i,j,found=0;for(i=0;i<=L.last;i++)if(x==L.data[i]){ found=1;for(j=i+1;j<=L.last;j++)L.data[j-1]=L.data[j];i--;L.last--;} if(found==0)printf(“x is not foundn”);else { printf(“x is deletedn”);printf(“the list after deletion is:n”);print_list(); 金陵科技学院实验报告 } } void main(){ int x,choice;while(1){ printf(“**********menu**********n”);printf(“ 1--printn”);printf(“ 2--searchn”);printf(“ 3--insertn”);printf(“ 4--deleten”);printf(“ 5--exitn”);printf(“please input your choice:”);scanf(“%d”,&choice); switch(choice){case 1: printf(“the original list is:n”);print_list();break;case 2: printf(“pls input x you want to search:n”); 金陵科技学院实验报告 scanf(“%d”,&x);find_all_x(x);break;case 3: printf(“pls input x you want to insert:n”);scanf(“%d”,&x);insert_x(x);printf(“the list after insertion is:n”);print_list();break;case 4: printf(“pls input x you want to delete:n”);scanf(“%d”,&x);delete_x(x);printf(“the list after deletion is:n”);print_list();break;case 5: exit(0);} } } 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 单链表 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验2 单链表 一、实验目的和要求 1、实验目的 掌握单链表的定位、插入、删除等操作。 2、实验要求 (1)注意链表的空间是动态分配的,某结点不用之后要及时进行物理删除,以便释放其内存空间。 (2)链表不能实现直接定位,一定注意指针的保存,防止丢失。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写程序建立一个单链表,并逐个输出单链表中所有数据元素。(2)在递增有序的单链表中插入一个新结点x,保持单链表的有序性。 解题思路:首先查找插入的位置然后进行插入操作;从第一个结点开始找到第一个大于该新结点值的结点即为插入位置;然后在找到的此结点之前插入新结点;注意保留插入位置之前结点的指针才能完成插入操作。 (3)编写实现带头结点单链表就地逆置的子函数,并编写主函数测试结果。 2、选做题 已知指针LA和LB分别指向两个无头结点单链表的首元结点。要求编一算法实现,从表LA中删除自第i个元素起共len个元素后,将它们插入到表LB中第j个元素之前。程序清单: 金陵科技学院实验报告 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 堆栈和队列 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验3 堆栈和队列 一、实验目的和要求 (1)掌握应用栈解决问题的方法。(2)掌握利用栈进行表达式求和的算法。 (3)掌握队列的存储结构及基本操作实现,并能在相应的应用问题中正确选用它们。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)判断一个算术表达式中开括号和闭括号是否配对。(2)测试“汉诺塔”问题。 (3)假设称正读和反读都相同的字符序列为”回文”,试写一个算法判别读入的一个以’@’为结束符的字符序列是否是“回文”。 2、选做题 在顺序存储结构上实现输出受限的双端循环队列的入列和出列算法。设每个元素表示一个待处理的作业,元素值表示作业的预计时间。入队列采取简化的短作业优先原则,若一个新提交的作业的预计执行时间小于队头和队尾作业的平均时间,则插入在队头,否则插入在队尾。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 串 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验4 串 一、实验目的和要求 掌握串的存储及应用。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)编写输出字符串s中值等于字符ch的第一个字符的函数,并用主函数测试结果。 (2)编写输出字符串s中值等于字符ch的所有字符的函数,并用主函数测试结果。 解题思路:可以将第一题程序改进成一个子函数,在本题中循环调用。(3)设字符串采用单字符的链式存储结构,编程删除串s从位置i开始长度为k的子串。 2、选做题 假设以链结构表示串,编写算法实现将串S插入到串T中某个字符之后,若串T中不存在这个字符,则将串S联接在串T的末尾。 提示:为提高程序的通用性,插入位置字符应设计为从键盘输入。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 二叉树 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验5 二叉树 一、实验目的和要求 (1)掌握二叉树的生成,以及前、中、后序遍历算法。(2)掌握应用二叉树递归遍历思想解决问题的方法。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)建立一棵二叉树。对此树进行前序遍历、中序遍历及后序遍历,输出遍历序列。 (2)在第一题基础上,求二叉树中叶结点的个数。(3)在第一题基础上,求二叉树中结点总数。(4)在第一题基础上,求二叉树的深度。 2、选做题 已知一棵完全二叉树存于顺序表sa中,sa.elem[1…sa.last]存储结点的值。试编写算法由此顺序存储结构建立该二叉树的二叉链表。 解题思路:根据完全二叉树顺序存储的性质来确定二叉树的父子关系即“还原”了二叉树,之后再按照二叉树二叉链表的构造方法进行建立。完全二叉树顺序存储的一个重要性质为,第i个结点的左孩子是编号为2i的结点,第i个结点的右孩子是编号为2i+1的结点。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 图 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验6 图 一、实验目的和要求 (1)熟练掌握图的基本概念、构造及其存储结构。 (2)熟练掌握对图的深度优先搜索遍历和广度优先搜索遍历的算法。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)构造一个无向图(用邻接矩阵表示存储结构)。 (2)对上面所构造的无向图,进行深度优先遍历和广度优先遍历,输出遍历序列。 2、选做题 采用邻接表存储结构,编写一个判别无向图中任意给定的两个顶点之间是否存在一条长度为k的简单路径的算法。简单路径是指其顶点序列中不含有重复顶点的路径。提示:两个顶点及k值均作为参数给出。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 排序 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验7 排序 一、实验目的和要求 (1)熟练掌握希尔排序、堆排序、直接插入排序、起泡排序、快速排序、直接选择排序、归并排序和基数排序的基本概念。 (2)掌握以上各种排序的算法。区分以上不同排序的优、缺点。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 用随机数产生100000个待排序数据元素的关键字值。测试下列各排序函数的机器实际执行时间(至少测试两个):直接插入排序、希尔排序(增量为4,2,1)、冒泡排序、快速排序、直接选择排序、堆排序。 2、选做题 假设含n个记录的序列中,其所有关键字为值介于v和w之间的整数,且其中很多关键字的值是相同的。则可按如下方法排序:另设数组number[v…w],令number[i]统计关键字为整数i的纪录个数,然后按number重排序列以达到有序。试编写算法实现上述排序方法,并讨论此种方法的优缺点。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 金陵科技学院实验报告 五、实验体会(遇到问题及解决办法,编程后的心得体会) 金陵科技学院实验报告 实验项目名称: 查找 实验学时: 2 同组学生姓名: 实验地点: 实验日期: 实验成绩: 批改教师: 批改时间: 金陵科技学院实验报告 实验8 查找 一、实验目的和要求 (1)掌握顺序表查找、有序表查找、索引顺序表查找的各种算法。(2)掌握哈希表设计。 二、实验仪器和设备 Turbo C 2.0/ Visual C++ 三、实验内容与过程(含程序清单及流程图) 1、必做题 (1)在一个递增有序的线性表中利用二分查找法查找数据元素X。 2、选做题 (2)构造一个哈希表,哈希函数采用除留余数法,哈希冲突解决方法采用链地址法。设计一个测试程序进行测试。 提示:构造哈希表只是完成查找的第一步,大家应该掌握在哈希表上进行查找的过程,可以试着编程序实现。程序清单: 金陵科技学院实验报告 四、实验结果与分析(程序运行结果及其分析) 五、实验体会(遇到问题及解决办法,编程后的心得体会)第二篇:算法与数据结构实验册
第三篇:算法与数据结构实验册
第四篇:算法与数据结构实验册
第五篇:算法与数据结构实验