实现两个链表的合并(数据结构课程设计c语言版)
- 格式:doc
- 大小:910.81 KB
- 文档页数:10
数据结构(C语言版)(第2版)课后习题答案李冬梅2015.3目录第1章绪论...................................................................................... 错误!未定义书签。
第2章线性表 .................................................................................. 错误!未定义书签。
第3章栈和队列 .............................................................................. 错误!未定义书签。
第4章串、数组和广义表 ............................................................... 错误!未定义书签。
第5章树和二叉树........................................................................... 错误!未定义书签。
第6章图............................................................................................ 错误!未定义书签。
第7章查找...................................................................................... 错误!未定义书签。
第8章排序...................................................................................... 错误!未定义书签。
C#两个list集合合并成⼀个,及升序降序在开发过程中.数组和集合的处理是最让我们担⼼.⼀般会⽤for or foreach 来处理⼀些操作.这⾥介绍⼀些常⽤的集合跟数组的操作函数. ⾸先举例2个集合A,B.List<int> listA = new List<int> {1,2,3,5,7,9};List<int> listB = new List<int> {13,4,17,29,2};listA.AddRange(listB );把集合A.B合并List<int> Result = listA.Union(listB).ToList<int>(); //剔除重复项List<int> Result = listA.Concat(listB).ToList<int>(); //保留重复项listA.BinarySearch("1");//判断集合中是否包含某个值.如果包含则返回0在举例两个数组int[] i=new int[]{1,2};int[] j=new int[]{2,3};List<int> r = new List<int>();r.AddRange(i);r.AddRange(j);int[] c = r.ToArray(); 合并数组int[] x=i.Union(j).ToArray<int>(); //剔除重复项int[] x=i.Concat(j).ToArray<int>(); //保留重复项int n = Array.BinarySearch(i,3);//判断数组中是否包含某个值.如果包含则返回0排序1、使⽤Sort()当T是简单类型,int,double之类的可以直接⽤var a = new List<int>();a.Add(1);a.Add(5);a.Add(4);a.Sort();//排序2、使⽤LinQa = a.OrderByDescending(i => ).ToList();//降序a = a.OrderBy(i => ).ToList();//升序。
数据结构(C语言版)(第2版)课后习题答案李冬梅2015.3目录第1章绪论 (1)第2章线性表 (5)第3章栈和队列 (13)第4章串、数组和广义表 (26)第5章树和二叉树 (33)第6章图 (42)第7章查找 (54)第8章排序 (65)第1章绪论1.简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。
答案:数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称。
如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形、图像、声音、动画等通过特殊编码定义后的数据。
数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。
在有些情况下,数据元素也称为元素、结点、记录等。
数据元素用于完整地描述一个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。
数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。
例如,学生基本信息表中的学号、姓名、性别等都是数据项。
数据对象:是性质相同的数据元素的集合,是数据的一个子集。
例如:整数数据对象是集合N={0,±1,±2,…},字母字符数据对象是集合C={‘A’,‘B’,…,‘Z’,‘a’,‘b’,…,‘z’},学生基本信息表也可是一个数据对象。
数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。
换句话说,数据结构是带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系。
逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。
因此,数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。
存储结构:数据对象在计算机中的存储表示,也称为物理结构。
抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。
具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。
实验一创建链表和链表操作一、实验目的掌握线性表的基本操作:插入、删除、查找、以及线性表合并等操作在顺序存储结构和链式存储结构上的实现。
二、实验内容:1. 创建单链表2.在链表上进行插入、删除操作;3.设计一个程序,用两个单链表分别表示两个集合,并求出这两个集合的并集。
四、测试数据:∙(3,9,5,6,11,8);在5之前插入4,7,并删除11∙求集合{1,12,8,6,4,9}和{2,5,12,7,4}的并集五、概要设计:本操作应完成如下功能:(1)创建链表说明:分配一定的空间,根据给定的链表长度输入值,创建链表。
(2)合并链表说明:将两个链表合并为一个链表只需修改链表头、尾指针即可实现。
(3)在链表中插入值说明:将给定的值插入到指定位置上,只需修改插入位置的前后结点的指针即可。
(4)在链表中删除值说明:将指定位置的值删除,只需修改删除位置的前后结点的指针即可。
六、详细设计:源代码:#include<stdio.h>#include<conio.h>#include<stdlib.h>#include<iostream.h>#define OK 1#define ERROR 0#define OVERFLOW 0//线性链表的存储结构,一个结点typedef struct LNode{int data; // 数据域struct LNode *next; // 指针域}LNode,*LinkList; //结点结构类型和指向结点的指针类型int TraverseList_L(LinkList L) //遍历单链表{LinkList p;p=L->next;while(p){printf("-->%d",p->data);p=p->next;}return OK;}//尾插法创建的带头结点的单链表。
void CreateList_L(LinkList &L,int &n){L=(LinkList)malloc(sizeof (LNode));//建立一个空链表L。
数学与计算科学学院实验报告
实验项目名称双向链表的算法设计与实现
所属课程名称__数据结构A
实验类型设计型
实验日期__
班级信计1402
学号201453100214
姓名俞凯烨
成绩
【实验小结】(收获体会)
附录1:源程序
附录2:实验报告填写说明
1.实验项目名称:要求与实验教学大纲一致。
2.实验目的:目的要明确,要抓住重点,符合实验教学大纲要求。
3.实验原理:简要说明本实验项目所涉及的理论知识。
4.实验环境:实验用的软、硬件环境。
5.实验方案(思路、步骤和方法等):这是实验报告极其重要的内容。
概括整个实验过程。
对于验证性实验,要写明依据何种原理、操作方法进行实验,要写明需要经过哪几个步骤来实现其操作。
对于设计性和综合性实验,在上述内容基础上还应该画出流程图、设计思路和设计方法,再配以相应的文字说明。
对于创新性实验,还应注明其创新点、特色。
6.实验过程(实验中涉及的记录、数据、分析):写明具体实验方案的具体实施步骤,包括实验过程中的记录、数据和相应的分析。
7.实验结论(结果):根据实验过程中得到的结果,做出结论。
8.实验小结:本次实验心得体会、思考和建议。
9.指导教师评语及成绩:指导教师依据学生的实际报告内容,给出本次实验报告的评价。
南昌大学实验报告学生姓名:李木子学号:8000113146 专业班级:软工133 实验类型:□验证□综合□设计□创新实验日期:实验成绩:一、实验项目名称两个有序顺序表的结合二、实验目的顺序表的创建1.实现顺序表的追加2.实现顺序表的显示3.两顺序表的合并三、实验基本原理四、主要仪器设备及耗材电脑,VC6.0五、实验步骤/*******************************************//* 顺序表的创建 *//* 1.实现顺序表的追加 *//* 2.实现顺序表的显示 *//* 3.两顺序表的合并 *//*******************************************/#include <stdio.h>#include <stdlib.h>#define MAXSIZE 100typedef int datatype;/************************************//* 顺序表结构体的定义 *//************************************/typedef struct{datatype a[MAXSIZE];int size;}sequence_list;/************************************//* 函数声明 *//************************************/void init(sequence_list *slt);void append(sequence_list *slt,datatype x);void display(sequence_list slt);int find(sequence_list slt ,datatype x);void dele(sequence_list *slt,datatype x);void sort(sequence_list *s);void combine( sequence_list *s1 ,sequence_list *s2 ,sequence_list *s3);/************************************//* 顺序表的初始化函数 *//************************************/void init(sequence_list *slt){slt->size=0;}/************************************//* 顺序表的追加函数 *//************************************/void append(sequence_list *slt,datatype x){if(slt->size==MAXSIZE){printf("\n顺序表是满的!");exit(1);}slt->a[slt->size]=x ;slt->size=slt->size+1;}/************************************/ /* 顺序表的显示函数 */ /************************************/ void display(sequence_list slt){int i;if(!slt.size){printf("\n顺序表为空");}else{for(i=0;i<slt.size;i++)printf("\n%d\n",slt.a[i]);}}/************************************/ /* 顺序表的查找函数 */ /* 返回所查数据的下标 */ /************************************/ int find(sequence_list slt ,datatype x) {int i=0;while(i<slt.size &&slt.a[i]!=x)i++;return(i<slt.size? i:-1);}/************************************/ /* 顺序表的删除函数 */ /************************************/ void dele(sequence_list *slt,datatype x) {int i=0;i=find(*slt,x);for(;i<slt->size-1;i++)slt->a[i]=slt->a [i+1];slt->size--;}/************************************//* 顺序表的插入函数 *//************************************/ void insert(sequence_list *slt,datatype x) {int i=0;i=find(*slt,x);for(;i<slt->size-1;i++)slt->a[i+1]=slt->a [i];slt->size++;}/************************************//* 顺序表排序 *//************************************/ void sort(sequence_list *s){int i ;int j ;int temp ;for(i=0;i<s->size-1;i++){for(j=i+1;j<s->size;j++){if(s->a[i]>=s->a[j]){temp=s->a[i];s->a[i]=s->a[j];s->a[j]=temp;}}}}/************************************//* 两个有序顺序表连接函数 *//************************************/void combine( sequence_list *s1 , sequence_list *s2 , sequence_list *s3 ) {int i=0;int j=0;int k=0;while( i < s1->size && j < s2->size){if(s1->a[i]<=s2->a[j]){s3->a[k]=s1->a[i];i++;}else{s3->a[k]=s2->a[j];j++;}k++;}if(i==s1->size){while(j<s2->size){s3->a[k]=s2->a[j];k++;j++;}}if(j==s2->size){while(i<s1->size){s3->a[k]=s1->a[i];k++;}}s3->size=k;}/************************************/ /* 主函数 */ /************************************/ int main(){int i ;int j ;int x ;int n ;sequence_list list1 ;sequence_list list2 ;sequence_list list3 ;init(&list1);printf("第一个顺序表元素个数:\n");scanf("%d",&n);printf("第一个顺序表输入:\n");for(i=0; i<n ; i++){scanf("%d",&list1.a[i]);list1.size++;}sort(&list1);printf("排序后\n");display(list1);init(&list2);printf("第二个顺序表元素个数:\n");scanf("%d",&n);printf("第二个顺序表输入:\n");for(i=0; i<n ; i++){scanf("%d",&list2.a[i]);list2.size++;}sort(&list2);printf("排序后\n");display(list2);init(&list3);combine(&list1 ,&list2 ,&list3);printf("表一与表二连接后:\n");display(list3);return0;}六、实验数据及处理结果七、思考讨论题或体会或对改进实验的认识八、参考资料[1]《数据结构(c语言版)(第三版)》,李云清,人民邮电出版社[2]《C语言程序设计》,苏小红,高等教育出版社教你如何用WORD文档(2012-06-27 192246)转载▼标签:杂谈1. 问:WORD 里边怎样设置每页不同的页眉?如何使不同的章节显示的页眉不同?答:分节,每节可以设置不同的页眉。
数据结构(C语言版)(第2版)课后习题答案李冬梅2015.3目录第1章绪论...................................................................................... 错误!未定义书签。
第2章线性表 .................................................................................. 错误!未定义书签。
第3章栈和队列 .............................................................................. 错误!未定义书签。
第4章串、数组和广义表 ............................................................... 错误!未定义书签。
第5章树和二叉树........................................................................... 错误!未定义书签。
第6章图............................................................................................ 错误!未定义书签。
第7章查找...................................................................................... 错误!未定义书签。
第8章排序...................................................................................... 错误!未定义书签。
c语言有序单链表的二路归并算法C语言有序单链表的二路归并算法一、引言有序单链表是一种常见的数据结构,其中的元素按照一定的顺序排列。
当需要将两个有序单链表合并为一个有序单链表时,可以使用二路归并算法。
本文将介绍使用C语言实现有序单链表的二路归并算法的原理和步骤。
二、算法原理二路归并算法是一种常见的排序算法,它通过将两个有序链表合并为一个有序链表的方式来实现排序。
算法的基本思想是通过比较两个链表中的元素大小,将较小的元素添加到新的链表中,直到将两个链表全部合并为止。
三、算法步骤下面是使用C语言实现有序单链表的二路归并算法的详细步骤:1. 定义两个指针,分别指向两个有序单链表的头结点;2. 创建一个新的链表,用于存储合并后的有序链表;3. 循环比较两个链表中的元素大小,将较小的元素添加到新链表中,并将指针后移;4. 当其中一个链表遍历完毕时,将另一个链表中剩余的元素添加到新链表的末尾;5. 返回新链表的头结点,即为合并后的有序单链表。
四、代码实现下面是使用C语言实现有序单链表的二路归并算法的示例代码:```c#include <stdio.h>#include <stdlib.h>// 定义链表结点typedef struct Node {int data;struct Node* next;} Node;// 创建有序链表Node* createList(int arr[], int size) {Node* head = NULL;Node* tail = NULL;for (int i = 0; i < size; i++) {Node* newNode = (Node*)malloc(sizeof(Node));newNode->data = arr[i];newNode->next = NULL;if (head == NULL) {head = newNode;tail = newNode;} else {tail->next = newNode;tail = newNode;}}return head;}// 合并两个有序链表Node* mergeList(Node* list1, Node* list2) { if (list1 == NULL) {return list2;}if (list2 == NULL) {return list1;}Node* head = NULL;Node* tail = NULL;while (list1 != NULL && list2 != NULL) { if (list1->data <= list2->data) {if (head == NULL) {head = list1;tail = list1;} else {tail->next = list1;tail = list1;}list1 = list1->next;} else {if (head == NULL) {head = list2;tail = list2;} else {tail->next = list2;tail = list2;}list2 = list2->next;}}if (list1 != NULL) {tail->next = list1;}if (list2 != NULL) {tail->next = list2;}return head;}// 打印链表void printList(Node* head) { Node* p = head;while (p != NULL) {printf("%d ", p->data); p = p->next;}printf("\n");}int main() {int arr1[] = {1, 3, 5};int arr2[] = {2, 4, 6};Node* list1 = createList(arr1, sizeof(arr1) / sizeof(int));Node* list2 = createList(arr2, sizeof(arr2) / sizeof(int));printf("链表1:");printList(list1);printf("链表2:");printList(list2);Node* mergedList = mergeList(list1, list2);printf("合并后的链表:");printList(mergedList);return 0;}```五、算法分析有序单链表的二路归并算法的时间复杂度为O(n),其中n为两个链表的总长度。
《数据结构(C语言版第2版)》(严蔚敏著)第二章练习题答案第2章线性表1.选择题(1)顺序表中第一个元素的存储地址是100,每个元素的长度为2,则第5个元素的地址是()。
A.110 B.108 C.100 D.120答案:B解释:顺序表中的数据连续存储,所以第5个元素的地址为:100+2*4=108。
(2)在n个结点的顺序表中,算法的时间复杂度是O(1)的操作是()。
A.访问第i个结点(1≤i≤n)和求第i个结点的直接前驱(2≤i≤n)B.在第i个结点后插入一个新结点(1≤i≤n)C.删除第i个结点(1≤i≤n)D.将n个结点从小到大排序答案:A解释:在顺序表中插入一个结点的时间复杂度都是O(n2),排序的时间复杂度为O(n2)或O(nlog2n)。
顺序表是一种随机存取结构,访问第i个结点和求第i个结点的直接前驱都可以直接通过数组的下标直接定位,时间复杂度是O(1)。
(3)向一个有127个元素的顺序表中插入一个新元素并保持原来顺序不变,平均要移动的元素个数为()。
A.8 B.63.5 C.63 D.7答案:B解释:平均要移动的元素个数为:n/2。
(4)链接存储的存储结构所占存储空间()。
A.分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针B.只有一部分,存放结点值C.只有一部分,存储表示结点间关系的指针D.分两部分,一部分存放结点值,另一部分存放结点所占单元数答案:A(5)线性表若采用链式存储结构时,要求内存中可用存储单元的地址()。
A.必须是连续的B.部分地址必须是连续的C.一定是不连续的D.连续或不连续都可以答案:D(6)线性表L在()情况下适用于使用链式结构实现。
A.需经常修改L中的结点值B.需不断对L进行删除插入C.L中含有大量的结点D.L中结点结构复杂答案:B解释:链表最大的优点在于插入和删除时不需要移动数据,直接修改指针即可。
(7)单链表的存储密度()。
A.大于1 B.等于1 C.小于1 D.不能确定答案:C解释:存储密度是指一个结点数据本身所占的存储空间和整个结点所占的存储空间之比,假设单链表一个结点本身所占的空间为D,指针域所占的空间为N,则存储密度为:D/(D+N),一定小于1。
课程设计报告课程设计题目:实现两个链表的合并
学生姓名
专业
班级
指导教师
2012年06 月21 日
一、课程设计目的:
课程设计为学生提供了一个既动手又动脑,独立实践的机会,将课本上的理论知识和实际有机的结合起来,锻炼学生的分析解决实际问题的能力。
提高学生适应实际,实践编程的能力。
二、课程设计题目:
实现两个链表的合并
要求:1)输入2个单链表
2)输出2个单链表合并后形成的结果。
三、模块划分:
(1)数据模块
参考使用课本上的具有头结点的链表抽象数据类型linklist,该抽象数据类型中包含一个elemtype类型的数据和一个指针,在开始用时,elemtype定义为整型变量,指针用来指向下一个元素。
对应的使用链表抽象数据类型linklist基本操作的函数有:初始化操作函数void ini(linklist *s)。
(2)创建链表模块
void create(linklist *s)
其功能是创建链表录入数据。
(3)输出数据模块
void display(linklist *s)
其功能为是输出s链表中的各项元素,从而验证操作是否成功
(4)排序模块
void sort(linklist *s)
此函数功能是s链表使用冒泡法对链表进行排序
(5)合并链表模块
void add(linklist *s1,linklist *s2)
其功能是按照题目要求实现两个链表的合并,将s2链表插入到s1链表中。
(6)主函数模块
void main(),函数中调用了各个模块的函数,从而实现了题目合并排序的要求
四、流程图:
五、算法设计分析
这个两个链表的交叉合并算法主要运用到的是链表的基本操作,定义节点,将链表的创建、链表的插入、链表内容升序排列,通过主函数调用。
这样就大大精简了主函数的操作。
但主函数中很大篇幅用到了if、else语句,用以指定链表指定结点,这样就使得本来很精简变得繁琐,降低了程序的质量。
所以其有优点和缺点,但需要不断的改进,不断优化该程序。
六、数据结构:
(1)数据类型DataType定义如下:
typedef int elemtype;
(2)带头结点链表抽象数据类型的结点结构定义如下:
typedef struct node
{
elemtype data;
struct node *next;
}linklist;
七、源程序:
#define null 0
typedef int elemtype;
typedef struct node
{
elemtype data;
struct node *next;
}linklist;
void ini(linklist *s)
{
s->next=null;
}
void create(linklist *s)
{
linklist *p,*q=s;
elemtype e;
printf("please input the data;\n"); scanf("%d",&e);
while(e!=-1)
{
p=(linklist *)malloc(sizeof(linklist)); p->data=e;
q->next=p;
q=q->next;
scanf("%d",&e);
}
q->next=null;
}
void display(linklist *s)
{
linklist *p=s->next;
if(s->next==null)
printf("the linklist is empty!\n"); else
{
printf("output the data:\n");
while(p!=null)
{
printf("%5d",p->data);
p=p->next;
}
}
printf("\n");
}
void sort(linklist *s)
{
linklist *p,*q;
elemtype t;
p=s->next;
while(p!=null)
{
q=p->next;
while(q!=null)
{
if(p->data>q->data)
{
t=p->data;
p->data=q->data;
q->data=t;
}
q=q->next;
}
p=p->next;
}
}
void add(linklist *s1,linklist *s2)
{
linklist *p1=s1->next,*p2=s1,*q1=s2->next,*q2=s2; if(s1==null)
s1=s2;
while(p1!=null&&q1!=null)
{
if(p1->data<q1->data)
{
p1=p1->next;
p2=p2->next
}
else
{
q2->next=q1->next;
q1->next=p2->next;
p2->next=q1;
p2=p2->next;
q1=q2->next;
}
}
if(q1!=null)
p2->next=q1;
}
void main()
{
linklist *s1,*s2;
s1=(linklist *)malloc(sizeof(linklist)); ini(s1);
create(s1);
display(s1);
sort(s1);
display(s1);
s2=(linklist *)malloc(sizeof(linklist)); ini(s2);
create(s2);
display(s2);
sort(s2);
display(s2);
add(s1,s2);
display(s1);
}
八、实验运行结果显示:
九、实验收获和体会:
十、参考文献
[1]赵国玲. C语言与数据结构[M]. 北京:电子工业出版社,1999.11:120-146
[2]严蔚敏,吴伟民. 数据结构(C语言版)[M]. 北京:清华大学出版社,2006.10:44-52
[3] 严蔚敏.数据结构 C语言[M].北京: 清华大学出版社,2006.10:110-135
[4]谭浩强. C程序设计指导[M].北京:清华大学出版社,2005。