问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

用c语言编写一段程序,建立一个顺序表,需要自己输入数据,并插入数据,删除数据

发布网友 发布时间:2022-04-23 18:19

我来回答

3个回答

热心网友 时间:2023-10-12 16:50

#include <stdio.h>
#define LIST_INIT_SIZE 10
#define LISTINCREMENT 10
#define ERROR 0
typedef struct{
 int *elem;
 int length;
 int listsize;
} SqList;
void InitList_Sq(SqList *l)
{
 l->elem=(int *)malloc(LIST_INIT_SIZE*sizeof(int));
 if(!l->elem) exit(0);
 l->length=0;
 l->listsize=LIST_INIT_SIZE;
}
int InList(SqList *l)
{
 int *p,*newbase;
 p=l->elem;
 while(1)
 {
  for(;p<l->elem+l->listsize;p++)
  {
   scanf("%d",p);if(*p==-1) break;l->length++;
  }
  if((p==l->elem+l->listsize))
  {
   newbase=(int *)realloc(l->elem,(l->listsize+LISTINCREMENT)*sizeof(int));
   p=l->elem+l->length;
   l->listsize=l->listsize+LISTINCREMENT; 
   if(!l->elem) return ERROR;
  }
  if(*p==-1) break;
 }
 return 1; 
}
void PrList(SqList *l)
{
 int *p,i;
 p=l->elem;
 for(;p<l->elem+l->length;p++)
 printf("%d ",*p);
}
int ListInsert_sq(SqList *l,int i,int e)
{
 int *newbase,*p,*q;
 if(i<1||i>l->length) return ERROR;
 if(l->length==l->listsize)
 {
  newbase=(int *)realloc(l->elem,(l->listsize+LISTINCREMENT)*sizeof(int));
  if(!newbase) return ERROR;
  l->elem=newbase;
  l->listsize+=LISTINCREMENT;
 }
 q=l->elem+i-1;
 for(p=l->elem+l->length-1;p>=q;p--)
 *(p+1)=*(p);
 *q=e;
 l->length+=1;
 return 1;
}
int ListDelet_sq(SqList *l,int i)
{
 int *p,e;
 if((i<1)||(i>l->length)) return ERROR;
 p=l->elem+i-1;
 e=*p;
 for(;p<l->elem+l->length-1;p++)
 *p=*(p+1);
 l->length--;
 printf("要删除的元素是:%d\n",e);
 return 1;
}
void main()
{
 int i,j,n;
 char a;
 SqList la;
 InitList_Sq(&la);
 printf("请输入顺序表中的元素:\n");
 if(!InList(&la)) return ERROR;
 do
 {
  printf("请输入需要插入元素的位置及元素:(a,b)\n");
  scanf("%d,%d",&i,&j);
  if(!ListInsert_sq(&la,i,j)) return ERROR;
  printf("是否还需要插入元素?(N/Y)");
  getchar();
  scanf("%c",&a);
  if(a=='N'||a=='n') break;
 }while(1);
 do
 { 
  printf("请输入需要删除元素的位置:\n");
  scanf("%d",&i);
  if(!ListDelet_sq(&la,i)) return ERROR;
  printf("是否还需要删除元素?(N/Y)");
  getchar();
  scanf("%c",&a);
  if(a=='N'||a=='n') break;
 }while(1);
 printf("最后的顺序表为:\n");
 PrList(&la); 
}

热心网友 时间:2023-10-12 16:51

http://wenku.baidu.com/view/af36b60b844769eae009ede8.html

我上传的自己下载吧,谢谢

热心网友 时间:2023-10-12 16:51

#include <stdio.h>
#define LIST_INIT_SIZE 10
#define LISTINCREMENT 10
#define ERROR 0
typedef struct{
int *elem;
int length;
int listsize;
} SqList;
void InitList_Sq(SqList *l)
{
l->elem=(int *)malloc(LIST_INIT_SIZE*sizeof(int));
if(!l->elem) exit(0);
l->length=0;
l->listsize=LIST_INIT_SIZE;
}
int InList(SqList *l)
{
int *p,*newbase;
p=l->elem;
while(1)
{
for(;p<l->elem+l->listsize;p++)
{
scanf("%d",p);if(*p==-1) break;l->length++;
}
if((p==l->elem+l->listsize))
{
newbase=(int *)realloc(l->elem,(l->listsize+LISTINCREMENT)*sizeof(int));
p=l->elem+l->length;
l->listsize=l->listsize+LISTINCREMENT;
if(!l->elem) return ERROR;
}
if(*p==-1) break;
}
return 1;
}
void PrList(SqList *l)
{
int *p,i;
p=l->elem;
for(;p<l->elem+l->length;p++)
printf("%d ",*p);
}
int ListInsert_sq(SqList *l,int i,int e)
{
int *newbase,*p,*q;
if(i<1||i>l->length) return ERROR;
if(l->length==l->listsize)
{
newbase=(int *)realloc(l->elem,(l->listsize+LISTINCREMENT)*sizeof(int));
if(!newbase) return ERROR;
l->elem=newbase;
l->listsize+=LISTINCREMENT;
}
q=l->elem+i-1;
for(p=l->elem+l->length-1;p>=q;p--)
*(p+1)=*(p);
*q=e;
l->length+=1;
return 1;
}
int ListDelet_sq(SqList *l,int i)
{
int *p,e;
if((i<1)||(i>l->length)) return ERROR;
p=l->elem+i-1;
e=*p;
for(;p<l->elem+l->length-1;p++)
*p=*(p+1);
l->length--;
printf("要删除的元素是:%d\n",e);
return 1;
}
void main()
{
int i,j,n;
char a;
SqList la;
InitList_Sq(&la);
printf("请输入顺序表中的元素:\n");
if(!InList(&la)) return ERROR;
do
{
printf("请输入需要插入元素的位置及元素:(a,b)\n");
scanf("%d,%d",&i,&j);
if(!ListInsert_sq(&la,i,j)) return ERROR;
printf("是否还需要插入元素?(N/Y)");
getchar();
scanf("%c",&a);
if(a=='N'||a=='n') break;
}while(1);
do
{
printf("请输入需要删除元素的位置:\n");
scanf("%d",&i);
if(!ListDelet_sq(&la,i)) return ERROR;
printf("是否还需要删除元素?(N/Y)");
getchar();
scanf("%c",&a);
if(a=='N'||a=='n') break;
}while(1);
printf("最后的顺序表为:\n");
PrList(&la);
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
怀孕错过了糖筛怎么办 糖筛有哪些注意事项 怀孕几个月查唐筛 蔡家沟镇慈云寺 哈佳高铁高楞站多少平方米位置在那 超威电池生产日期怎么看 超威电池寿命一般多长时间 华晨宇鸟巢四面台10w+秒罄!!火星演唱会舞台概念图震撼发布! 手机连接160wifi电脑蓝屏使用160WiFi遇到问题应该如何解决 为什么手机wifi总是刚开启,锁屏就掉了。wifi设置里的休眠模式也是永久的... 建行卡为什么不能网上转账 学校发我们的建设银行卡一定要激活吗? 我打电话查余额说输入取钱密码... C语言:建立一个学生信息数据库 C语言:1.建立含n个数据元素的顺序表并输出该表中各元素的值及顺序表的长度。 紧急求 速度 c语言如何用链表构建数据结构并实现数据的输入和保存? c语言如何创建一个txt文件并写入数据? c语言中如何建立数据库 如何用C语言建立数据库 经常喝柠檬水,真的会让人变白吗? C语言中 如何建立一个储存数据的文件 你有过哪些经历从来没有对人说过? 把王八跟金鱼放到冰箱里结果金鱼对着王八笑了,这是为啥 贺来贤人到底有几个孩子? 电影深海巨鲨里面那个DJ手上戴的那个手表是什么牌子的? 求2012世界末日电影百度云资源_(:3」∠)_ 您好,刚才看到了一条消息,不知是否给我的回答?请确认一下,谢谢! 金融词汇解释,什么叫离岸?? 什么叫做离岸人民币?怎样才可能参与离岸交易? 你喜欢的歌词或现代诗词? 什么是离岸人民币,什么叫在岸人民币,请知道的告诉我,谢谢! 林俊杰的新专辑叫什么名字? 在岸人民币和离岸人民币6.99啥意思? 喝柠檬水真的会变白吗?为什么? 用c语言编写一段程序,建立一个顺序表(需要自己输入数据,并插入数据、删除数据)。 C语言数据结构 堆的建立和维护 C语言编写 数据结构 数据结构(C语言版) 建立二叉树数据怎么输入? C语言写出一个建立并写入数据的二进制文件,文件后缀为.dat。 C语言编写的创建并写入数据,文件路径如何由用户输入? 如何用c语言把生成的数据创建成一个文档? 怎么和电脑多屏互动 多屏互动在哪 找不到多屏互动设备怎么办 windows 7 怎么开启多屏互动? 手机电脑多屏互动怎么用? windows 7 怎么开启多屏互动 电脑怎样实现多屏互动,即一个屏幕两个桌面, win10和电视机怎么多屏互动 初春钓草鱼有什么秘方 电脑跟电视可以实现无线多屏互动吗 春季在水库如何台钓草鱼技巧 苹果8p音量键开到最大还是没声音咋办?