数据结构顺序表的c语言代码实现,主函数测试时插入和删除操作不能得到预期结果

#include<stdio.h>#defineMaxsize50#defineFALSE0#defineTRUE1typedefintElemType;typedefi... #include <stdio.h>
#define Maxsize 50
#define FALSE 0
#define TRUE 1
typedef int ElemType;
typedef int Status;
typedef struct{
ElemType data[Maxsize];
int length;
}SqList;
Status LocateElem(SqList L,int e){//按值查找
int i;
if(L.length==0)
return FALSE;
for(i=0;i<L.length;i++){
if(L.data[i]==e)
return i+1;
}
return FALSE;
}
Status Insert(SqList L,int i,int e){//插入操作
int j;
if(L.length==Maxsize)
return FALSE;
if(i<1||i>L.length+1)
return FALSE;
for(j=L.length-1;j>=i-1;j--)
L.data[j+1]=L.data[j];
L.data[i-1]=e;
L.length++;
return TRUE ;
}
Status Delete(SqList L,int i){//删除操作
int j;
if(L.length==0)
return FALSE;
for(j=i;j<L.length;j++){
L.data[j-1]=L.data[j];
}
L.length--;
return TRUE;
}
SqList CreateList(SqList L){
int i;
L.length=30;
for(i=0;i<L.length;i++){
L.data[i]=i+1;
}
return L;
}
void printSqList(SqList L){
int i;
for(i=0;i<L.length;i++){
printf("顺序表第%d个元素值为%d\n",i+1,L.data[i]);
}
printf("\n\n");
}

void main(){
int k;
int e; //待查元素
int insertData;//待插元素
int insert_location,delete_location;//插入位置及删除位置
int isInserted,isDeleted;//判断是否插入或删除成功
SqList L=CreateList(L);
printSqList(L);

printf("请输入您要查找的值:");
scanf("%d",&e);
k=LocateElem(L,e);
printf("您要查找的值在顺序表第%d个\n",k);
printf("\n\n");

printf("请输入您要插入的位置:");
scanf("%d",&insert_location);
printf("\n");
printf("请输入您要插入的值:");
scanf("%d",&insertData);

isInserted=Insert(L,insert_location,insertData);
if(isInserted){
printf("%d",L.data[insert_location-1]);
}
printf("\n\n");

printf("请输入您要删除的位置:");
scanf("%d",&delete_location);
printf("\n");
isDeleted=Delete(L,delete_location);
if(isDeleted){
printf("\n");
printSqList(L);
}

}
展开
 我来答
jhanker
推荐于2018-04-16 · TA获得超过1479个赞
知道小有建树答主
回答量:675
采纳率:73%
帮助的人:501万
展开全部

你的代码中的插入和删除操作根本就无法实现,应为函数无法修改main()函数中传入的实参变量的,把形参改成指针才行

代码改成如下:

#include <stdio.h>
#define Maxsize 50
#define FALSE 0
#define TRUE 1
typedef int ElemType;
typedef int Status;
typedef struct{
ElemType data[Maxsize];
int length;
}SqList;
Status LocateElem(SqList L,int e){//按值查找
int i;
if(L.length==0)
return FALSE;
for(i=0;i<L.length;i++){
if(L.data[i]==e)
return i+1;
}
return FALSE;
}
Status Insert(SqList *L,int i,int e){//插入操作 //修改成指针
int j;
if(L->length==Maxsize) //把 .改成 ->
return FALSE;
if(i<1||i>L->length+1)
return FALSE;
for(j=L->length-1;j>=i-1;j--) //把 .改成 ->
L->data[j+1]=L->data[j];//把 .改成 ->
L->data[i-1]=e;//把 .改成 ->
L->length++;//把 .改成 ->
return TRUE ;
}
Status Delete(SqList * L,int i){//删除操作 //修改成指针
int j;
if(L->length==0)//把 .改成 ->
return FALSE;
for(j=i;j<L->length;j++){//把 .改成 ->
L->data[j-1]=L->data[j];//把 .改成 ->
}
L->length--;//把 .改成 ->
return TRUE;
}
SqList CreateList(SqList L){
int i;
L.length=30;
for(i=0;i<L.length;i++){
L.data[i]=i+1;
}
return L;
}
void printSqList(SqList L){
int i;
for(i=0;i<L.length;i++){
printf("顺序表第%d个元素值为%d\n",i+1,L.data[i]);
}
printf("\n\n");
}
void main(){
int k;
int e;        //待查元素
int insertData;//待插元素
int insert_location,delete_location;//插入位置及删除位置
int isInserted,isDeleted;//判断是否插入或删除成功
SqList L=CreateList(L);
printSqList(L);
printf("请输入您要查找的值:");
scanf("%d",&e);
k=LocateElem(L,e);
printf("您要查找的值在顺序表第%d个\n",k);
printf("\n\n");
printf("请输入您要插入的位置:");
scanf("%d",&insert_location);
printf("\n");
printf("请输入您要插入的值:");
scanf("%d",&insertData);
isInserted=Insert(&L,insert_location,insertData);
if(isInserted){
printf("%d",L.data[insert_location-1]);
}
printf("\n\n");
printf("请输入您要删除的位置:");
scanf("%d",&delete_location);
printf("\n");
isDeleted=Delete(&L,delete_location);
if(isDeleted){
printf("\n");
printSqList(L);
}
}

如果是C++可以把函数变成引用,那更简单

光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式