C语言代码详细描述顺序线性表

 更新时间:2021年9月26日 16:01  点击:1921

代码内容包括:

1.表的创建

2.增删改查插

3.界面跳转

代码实现如下:

#include <stdio.h>
#include<stdlib.h>
#define MaxSize 20
typedef int ElemType;//将int类型赋予别名
//创建结构体
typedef struct{
ElemType A[MaxSize];//MaxSize是给表的一个预估容量
int n;//n是指当前A的元素个数,记录当下表的大小
}seqList,*pSeqList;//给结构体赋予名字以及创建一个结构体类型的指针

//函数声明
void ADD(pSeqList L);
void Delete(pSeqList L);
void Insert(pSeqList L);
void welcome(pSeqList L);
void Correct(pSeqList L);
void search(pSeqList L);
void view(pSeqList L);
//表的创建
pSeqList CREATE(){
pSeqList L;
L=(pSeqList)malloc(sizeof(seqList));
if(L==NULL){
printf("Failure\n");//判断创建是否成功
return 0;
}
else{
printf("success!");
L->n=0;
}
return L;
}
//主函数
int main(){
pSeqList head;
head=CREATE();
welcome(head);
system("pause");
return 0;
}
//增添元素
void ADD(pSeqList L){
	system("cls");
	int k;
	for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
	int adder;
	int choose=0;
	do{
	if(L->n==MaxSize){
	printf("表已满,无法添加!\n");
	}
	else{
	printf("添加元素:");
    scanf("%d",&adder);
	L->A[L->n]=adder;
	L->n++;
	printf("已成功添加:%d 添加后元素个数为:%d\n\n",L->A[(L->n)-1],L->n);
	}
printf("是否继续添加?\n1、继续添加   2、返回主界面\n");
scanf("%d",&choose);
system("cls");//表示将当前页面清空
}while(choose==1);
	if(choose==2){
	welcome(L);}
	else welcome(L);
}
//删除
void Delete(pSeqList L){
	int j;
	int k;
	int i;
	int choose=0;
	for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
	do{
	system("cls");
	printf("删除界面\n");
	for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
	if(L->n==NULL){
	printf("表为空!");
	break;
	}
	printf("请输入你要删除第几个元素:");
	scanf("%d",&i);
	if(i<1||i>L->n){
	printf("\n删除的数据位置有误!\n");
	}
	else{
		for(j=i;j<=L->n-1;j++)
		    L->A[j-1]=L->A[j];
		L->n--;
		printf("删除成功!\n");
	}
	printf("删除后的元素为:\n");
	for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
	printf("是否继续删除?\n1.继续删除  2.返回主界面\n");
	scanf("%d",&choose);
}while(choose==1);
	if(choose==2){
	welcome(L);}
	else welcome(L);
}
//插入元素
void Insert(pSeqList L){
int i;
int item;
int j;
int choose=0;
int choosex;
int k;
system("cls");
if(L->n==NULL){
			printf("\n\n\n元素为空!是否添加元素?1.是  2.返回主菜单");
			scanf("%d",&choosex);
			if(choosex==1)
			{
				ADD(L);
			}
			else welcome(L);
		}
for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
do{
printf("插入元素\n");
if(L->n==MaxSize){
printf("表满!\n");
break;
}
printf("请输入你想插入的位置:");
scanf("%d",&i);
system("cls");
if(i<1||i>L->n+1){
printf("\n插入位置错误!\n");
}
printf("请输入你想插入的数据:");
scanf("%d",&item);
for(j=L->n-1;j>i-2;j--)
		L->A[j+1]=L->A[j];
L->A[i-1]=item;
L->n++;
printf("插入成功!插入后的数据为;\n");
for(k=0;k<L->n;k++){
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
printf("\n是否继续插入?\n1.继续插入  2.返回主界面");
scanf("%d",&choose);
}while(choose==1);
	if(choose==2){
	welcome(L);}
	else welcome(L);
}
//修改元素
void Correct(pSeqList L){
	int cn;
	int item;
	int k;
	int choose;
		system("cls");
		if(L->n==NULL){
			printf("\n\n\n元素为空!是否添加元素?1.是  2.返回主菜单");
			scanf("%d",&choose);
			if(choose==1)
			{
				ADD(L);
			}
			else welcome(L);
		}
		//*******************************************
	   for(k=0;k<L->n;k++)
	  {
     	printf("第%d个元素:%d\n",k+1,L->A[k]);
       }
	   //********************************************
	   do{
	      printf("请输入你要修改的元素序号:");
	      scanf("%d",&cn);
	      if(cn<1||cn>L->n){
			  printf("输入错误请重新输入:");
		  }
	   }while(cn<1||cn>L->n);
	printf("\n请输入你想修改成的数据:");
	scanf("%d",&item);
	L->A[cn-1]=item;
	system("cls");
	printf("修改后的数据为:\n");
	for(k=0;k<L->n;k++)
	{
	printf("第%d个元素:%d\n",k+1,L->A[k]);
	}
	printf("是否继续修改?1.是  2.返回主菜单");
	scanf("%d",&choose);
	if(choose==1){
	Correct(L);
	}
	else welcome(L);
}
//查找元素
void search(pSeqList L){
	int mchoose;
	int choose;
	int choose1;
	int choose2;
	int num;
	int item;
	int i;
	int j=0;
	system("cls");
	if(L->n==NULL){
			printf("\n\n\n元素为空!是否添加元素?1.是  2.返回主菜单");
			scanf("%d",&choose);
			if(choose==1)
			{
				ADD(L);
			}
			else welcome(L);
		}
	printf("*****查找方式选择*****\n\n1.输入序号以寻找对应数据\n2.输入数据找到对应的序号\n3.返回主菜单\n");
	scanf("%d",&mchoose);
	system("cls");
	if(mchoose==3){
	welcome(L);
	}
	if(mchoose==1)
	{
		do
		{
	     printf("请输入序号:");
	     scanf("%d",&num);
	     printf("序号:%d 数据:%d\n",num,L->A[num-1]);
	     printf("1.继续输入  2.返回上一级");
		 scanf("%d",&choose2);
	    }while(choose2==1);
	   if(choose2!=1)
	   {
	   search(L);
	   }
	}
	else if(mchoose==2)
	{
		do
	   {
		printf("请输入数据:");
	    scanf("%d",&item);
		for(i=0;i<L->n;i++)
		{
			if(item==L->A[i])
			{
			printf("元素:%d  序号:%d\n",i+1,item);j=1;
			}
		}
		if(j==0){printf("您输入的元素不存在!");}
        printf("1.继续输入  2.返回上一级");
		scanf("%d",&choose1);
	    }while(choose1==1);
	   if(choose1!=1){
	   search(L);
	   }
	}
	else 
	{
       search(L);
	}
}
//浏览全部元素
void view(pSeqList L)
{
	int k;
	char choose[10];
	int choosey;
	if(L->n==NULL)
	  {
			printf("\n\n\n元素为空!是否添加元素?1.是  2.返回主菜单");
			scanf("%d",&choosey);
			if(choosey==1)
			{
				ADD(L);
			}
			else welcome(L);
		}
	for(k=0;k<L->n;k++)
	  {
     	printf("第%d个元素:%d\n",k+1,L->A[k]);
       }
	printf("输入任意字符以返回菜单");
	scanf("%s",choose);
	getchar();
	if(choose!=NULL)
	{
		welcome(L);
	}
}
//欢迎界面
void welcome(pSeqList L){
	pSeqList head;
	head=L;
	int welchoose=0;
	system("cls");
printf("\t\t\t\***************************************\n");
printf("\t\t\t\t\t顺序表功能选择\n");
printf("\t\t\t\t\t1.添加元素\n");
printf("\t\t\t\t\t2.删除元素\n");
printf("\t\t\t\t\t3.插入元素\n");
printf("\t\t\t\t\t4.修改元素\n");
printf("\t\t\t\t\t5.查找元素\n");
printf("\t\t\t\t\t6.浏览元素\n");
printf("\t\t\t\***************************************\n");
scanf("%d",&welchoose);
switch(welchoose){
case 1:ADD(head);break;
case 2:Delete(head);break;
case 3:Insert(head);break;
case 4:Correct(head);break;
case 5:search(head);break;
case 6:view(head);break;
default :printf("输入错误!");main();break;
}
}

总结

以上为线性顺序表的基本操作,若发现错误,敬请各位读者指正!

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注猪先飞的更多内容!

[!--infotagslink--]

相关文章

  • C语言实现放烟花的程序

    这篇文章主要为大家详细介绍了C语言实现放烟花的程序,有音乐播放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-23
  • C语言中的字符(char)详细讲解

    本篇文章主要介绍C语言中char的知识,并附有代码实例,以便大家在学习的时候更好的理解,有需要的可以看一下...2020-04-25
  • 详解如何将c语言文件打包成exe可执行程序

    这篇文章主要介绍了详解如何将c语言文件打包成exe可执行程序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-25
  • 不打开网页直接查看网站的源代码

      有一种方法,可以不打开网站而直接查看到这个网站的源代码..   这样可以有效地防止误入恶意网站...   在浏览器地址栏输入:   view-source:http://...2016-09-20
  • php 调用goolge地图代码

    <?php require('path.inc.php'); header('content-Type: text/html; charset=utf-8'); $borough_id = intval($_GET['id']); if(!$borough_id){ echo ' ...2016-11-25
  • JS基于Mootools实现的个性菜单效果代码

    本文实例讲述了JS基于Mootools实现的个性菜单效果代码。分享给大家供大家参考,具体如下:这里演示基于Mootools做的带动画的垂直型菜单,是一个初学者写的,用来学习Mootools的使用有帮助,下载时请注意要将外部引用的mootools...2015-10-23
  • For循环中分号隔开的3部分的执行顺序探讨

    引发这个问题思考的是一段js程序的运行结果: 复制代码 代码如下: var i = 0; function a(){ for(i=0;i<20;i++){ } } function b(){ for(i=0;i<3;i++){ a(); } return i; } var Result = b(); 这段程序的运行结果是Re...2014-05-31
  • JS+CSS实现分类动态选择及移动功能效果代码

    本文实例讲述了JS+CSS实现分类动态选择及移动功能效果代码。分享给大家供大家参考,具体如下:这是一个类似选项卡功能的选择插件,与普通的TAb区别是加入了动画效果,多用于商品类网站,用作商品分类功能,不过其它网站也可以用,...2015-10-21
  • JS实现自定义简单网页软键盘效果代码

    本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下:这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学...2015-11-08
  • php 取除连续空格与换行代码

    php 取除连续空格与换行代码,这些我们都用到str_replace与正则函数 第一种: $content=str_replace("n","",$content); echo $content; 第二种: $content=preg_replac...2016-11-25
  • php简单用户登陆程序代码

    php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p>&nbsp;</p> <p>&nbsp;</p> <form name="form1...2016-11-25
  • PHP实现清除wordpress里恶意代码

    公司一些wordpress网站由于下载的插件存在恶意代码,导致整个服务器所有网站PHP文件都存在恶意代码,就写了个简单的脚本清除。恶意代码示例...2015-10-23
  • js识别uc浏览器的代码

    其实挺简单的就是if(navigator.userAgent.indexOf('UCBrowser') > -1) {alert("uc浏览器");}else{//不是uc浏览器执行的操作}如果想测试某个浏览器的特征可以通过如下方法获取JS获取浏览器信息 浏览器代码名称:navigator...2015-11-08
  • JS实现双击屏幕滚动效果代码

    本文实例讲述了JS实现双击屏幕滚动效果代码。分享给大家供大家参考,具体如下:这里演示双击滚屏效果代码的实现方法,不知道有觉得有用处的没,现在网上还有很多还在用这个特效的呢,代码分享给大家吧。运行效果截图如下:在线演...2015-10-30
  • JS日期加减,日期运算代码

    一、日期减去天数等于第二个日期function cc(dd,dadd){//可以加上错误处理var a = new Date(dd)a = a.valueOf()a = a - dadd * 24 * 60 * 60 * 1000a = new Date(a)alert(a.getFullYear() + "年" + (a.getMonth() +...2015-11-08
  • PHP开发微信支付的代码分享

    微信支付,即便交了保证金,你还是处理测试阶段,不能正式发布。必须到你通过程序测试提交订单、发货通知等数据到微信的系统中,才能申请发布。然后,因为在微信中是通过JS方式调用API,必须在微信后台设置支付授权目录,而且要到...2014-05-31
  • C语言中free函数的使用详解

    free函数是释放之前某一次malloc函数申请的空间,而且只是释放空间,并不改变指针的值。下面我们就来详细探讨下...2020-04-25
  • C语言中计算正弦的相关函数总结

    这篇文章主要介绍了C语言中计算正弦的相关函数总结,包括正弦和双曲线正弦以及反正弦的函数,需要的朋友可以参考下...2020-04-25
  • 详解C语言中的rename()函数和remove()函数的使用方法

    这篇文章主要介绍了详解C语言中的rename()函数和remove()函数的使用方法,是C语言入门学习中的基础知识,需要的朋友可以参考下...2020-04-25
  • PHP常用的小程序代码段

    本文实例讲述了PHP常用的小程序代码段。分享给大家供大家参考,具体如下:1.计算两个时间的相差几天$startdate=strtotime("2009-12-09");$enddate=strtotime("2009-12-05");上面的php时间日期函数strtotime已经把字符串...2015-11-24