一、实验目的
了解和掌握线性表的顺序存储结构;掌握用C语言上机调试线性表的基本方法;掌握线性表的基本操作:插入、删除、查找以及线性表合并等运算在顺序存储结构和链接存储结构上的运算,以及对相应算法的性能分析。
二、实验要求
给定一段程序代码,程序代码所完成的功能为:(1)建立一个线性表;(2)依次输入数据元素1,2,3,4,5,6,7,8,9,10;(3)删除数据元素5;(4)依次显示当前线性表中的数据元素。假设该线性表的数据元素个数在最坏情况下不会超过100个,要求使用顺序表。
程序中有3处错误的地方,有标识,属于逻辑错误,对照书中的代码仔细分析后,要求同学们修改错误的代码,修改后上机调试得到正确的运行结果。
三、程序代码
#include
#define MaxSize 100
typedef int DataType;
typedef struct
{
DataType list[MaxSize];
int size;
} SeqList;
void ListInitiate(SeqList *L)/初始化顺序表L/
{
L->size = 0;/定义初始数据元素个数/
}
int ListLength(SeqList L)/返回顺序表L的当前数据元素个数/
{
return L.size;
}
int ListInsert(SeqList *L, int i, DataType x)
/在顺序表L的位置i(0 ≤ i ≤ size)前插入数据元素值x/
/插入成功返回1,插入失败返回0/
{
int j;
if(L->size >= MaxSize)
{
printf(“顺序表已满无法插入! \n”);
return 0;
}
else if(i < 0 || i > L->size )
{
printf(“参数i不合法! \n”);
return 0;
}
else
{ //此段程序有一处错误
for(j = L->size; j > i; j–) L->list[j+1] = L->list[j];/为插入做准备/
L->list[i] = x;/插入/
L->size ++;/元素个数加1/
return 1;
}
}
int ListDelete(SeqList *L, int i, DataType *x)
/删除顺序表L中位置i(0 ≤ i ≤ size - 1)的数据元素值并存放到参数x中/
/删除成功返回1,删除失败返回0/
{
int j;
if(L->size <= 0)
{
printf(“顺序表已空无数据元素可删! \n”);
return 0;
}
else if(i < 0 || i > L->size-1)
{
printf(“参数i不合法”);
return 0;
}
else
{//此段程序有一处错误
*x = L->list[i];/保存删除的元素到参数x中/
for(j = i +1; j <= L->size-1; j++) L->list[j] = L->list[j-1];/依次前移/
L->size–;/数据元素个数减1/
return 1;
}
}
int ListGet(SeqList L, int i, DataType *x)
/取顺序表L中第i个数据元素的值存于x中,成功则返回1,失败返回0/
{
if(i < 0 || i > L.size-1)
{
printf(“参数i不合法! \n”);
return 0;
}
else
{
*x = L.list[i];
return 1;
}
}
void main(void)
{ SeqList myList;
int i , x;
ListInitiate(&myList);
for(i = 0; i < 10; i++)
ListInsert(&myList, i, i+1);
ListDelete(&myList, 4, &x);
for(i = 0; i < ListLength(myList); i++)
{
ListGet(,i,&x); //此段程序有一处错误
printf("%d", x);
}
}
四、实验任务
1.改正上述程序中的错误。
2.编写合并函数,将两个有序线性表合并为一个有序表并在主函数中加以测试。
3.完成实验报告的撰写。
代码如下:
#include
#define MaxSize 100
typedef int DataType;
typedef struct
{
DataType list[MaxSize];
int size;
} SeqList;
void ListInitiate(SeqList *L)/*初始化顺序表L*/
{
L->size = 0;/*定义初始数据元素个数*/
}
int ListLength(SeqList L)/*返回顺序表L的当前数据元素个数*/
{
return L.size;
}
int ListInsert(SeqList *L, int i, DataType x)
/*在顺序表L的位置i(0 ≤ i ≤ size)前插入数据元素值x*/
/*插入成功返回1,插入失败返回0*/
{
int j;
if(L->size >= MaxSize)
{
printf("顺序表已满无法插入! \n");
return 0;
}
else if(i < 0 || i > L->size )
{
printf("参数i不合法! \n");
return 0;
}
else
{
//此段程序有一处错误
for(j = L->size; j > i; j--) L->list[j] = L->list[j-1];/*为插入做准备*/
L->list[i] = x;/*插入*/
L->size ++;/*元素个数加1*/
return 1;
}
}
int ListDelete(SeqList *L, int i, DataType *x)
/*删除顺序表L中位置i(0 ≤ i ≤ size - 1)的数据元素值并存放到参数x中*/
/*删除成功返回1,删除失败返回0*/
{
int j;
if(L->size <= 0)
{
printf("顺序表已空无数据元素可删! \n");
return 0;
}
else if(i < 0 || i > L->size-1)
{
printf("参数i不合法");
return 0;
}
else
{
//此段程序有一处错误
*x = L->list[i];/*保存删除的元素到参数x中*/
for(j = i +1; j <= L->size-1; j++) L->list[j-1] = L->list[j];/*依次前移*/
L->size--;/*数据元素个数减1*/
return 1;
}
}
int ListGet(SeqList L, int i, DataType *x)
/*取顺序表L中第i个数据元素的值存于x中,成功则返回1,失败返回0*/
{
if(i < 0 || i > L.size-1)
{
printf("参数i不合法! \n");
return 0;
}
else
{
*x = L.list[i];
return 1;
}
}
int main()
{
SeqList myList;
int i, x;
ListInitiate(&myList);
for(i = 0; i < 10; i++)
ListInsert(&myList, i, i+1);
ListDelete(&myList, 4, &x);
for(i = 0; i < ListLength(myList); i++)
{
ListGet(myList,i,&x); //此段程序有一处错误
printf("%d", x);
}
return 0;
}
第二题
#include
#include
#define MaxSize 100
typedef int DataType;
typedef struct
{
DataType list[MaxSize];
int size;
} SeqList;
void ListInitiate(SeqList *L)/*初始化顺序表L*/
{
L->size = 0;/*定义初始数据元素个数*/
}
int ListLength(SeqList L)/*返回顺序表L的当前数据元素个数*/
{
return L.size;
}
int ListInsert(SeqList *L, int i, DataType x)
/*在顺序表L的位置i(0 ≤ i ≤ size)前插入数据元素值x*/
/*插入成功返回1,插入失败返回0*/
{
int j;
if(L->size >= MaxSize)
{
printf("顺序表已满无法插入! \n");
return 0;
}
else if(i < 0 || i > L->size )
{
printf("参数i不合法! \n");
return 0;
}
else
{
//此段程序有一处错误
for(j = L->size; j >= i; j--) L->list[j+1] = L->list[j];/*为插入做准备*/
L->list[i] = x;/*插入*/
L->size ++;/*元素个数加1*/
return 1;
}
}
int ListDelete(SeqList *L, int i, DataType *x)
/*删除顺序表L中位置i(0 ≤ i ≤ size - 1)的数据元素值并存放到参数x中*/
/*删除成功返回1,删除失败返回0*/
{
int j;
if(L->size <= 0)
{
printf("顺序表已空无数据元素可删! \n");
return 0;
}
else if(i < 0 || i > L->size-1)
{
printf("参数i不合法");
return 0;
}
else
{
//此段程序有一处错误
*x = L->list[i];/*保存删除的元素到参数x中*/
for(j = i+1; j <= L->size-1; j++)
L->list[j-1] = L->list[j];/*依次前移*/
L->size--;/*数据元素个数减1*/
return 1;
}
}
int ListGet(SeqList L, int i, DataType *x)
/*取顺序表L中第i个数据元素的值存于x中,成功则返回1,失败返回0*/
{
if(i < 0 || i > L.size-1)
{
printf("参数i不合法! \n");
return 0;
}
else
{
*x = L.list[i];
return 1;
}
}
void MergeList(SeqList La,SeqList Lb,SeqList Lc)
{
DataType* pa;
DataType* pb;
DataType* pc;
DataType* pa_last;
DataType* pb_last;
pa = La.list;
pb = Lb.list;
pc = Lc.list;
Lc.size = La.size + Lb.size;
if(!Lc.list) exit(-1);
pa_last = La.list + La.size-1;
pb_last = Lb.list + Lb.size-1;
while(pa <=pa_last&&pb<pb_last)
{
if(*pa<= *pb) *pc++ = *pa++;
else *pc++ = *pb++;
}
while(pa<= pa_last) *pc++ = *pa++;
while(pb<= pb_last) *pc++ = *pb++;
for(int i = 0,x=0; i < ListLength(Lc); i++)
{
ListGet(Lc,i,&x); //此段程序有一处错误
printf("%d ", x);
}
printf("\n");
}
int main(void)
{
int i,x,j;
SeqList La,Lb,Lc;
ListInitiate(&La);
ListInitiate(&Lb);
ListInitiate(&Lc);
for(i = 0,j=0; i < 10; i++,j+=2)
ListInsert(&La, i, j);
for(i = 0,j=1; i < 10; i++,j+=2)
ListInsert(&Lb, i, j);
for(i = 0; i < ListLength(La); i++)
{
ListGet(La,i,&x); //此段程序有一处错误
printf("%d ", x);
}
printf("\n");
for(i = 0; i < ListLength(Lb); i++)
{
ListGet(Lb,i,&x); //此段程序有一处错误
printf("%d ", x);
}
printf("\n");
MergeList(La,Lb,Lc);
/*
SeqList myList;
int i, x;
ListInitiate(&myList);
for(i = 0; i < 10; i++)
ListInsert(&myList, i, i+1);
ListDelete(&myList, 4, &x);
for(i = 0; i < ListLength(myList); i++)
{
ListGet(myList,i,&x); //此段程序有一处错误
printf("%d", x);
}
*/
}
求赞 ‘-’