昨天做了个题,感觉开心死了
/* Note:Your choice is C IDE */#include "stdio.h"
#define N 20
struct list
{
int data[N];
int length;
};
void main()
{
struct list s;
int i,t,key,xia;
while(1)
{
printf("1:输入五个数\n");
printf("2:插入一个数\n");
printf("3:删除一个数\n");
printf("4:输出所有的数\n");
printf("0:退出\n");
printf("请输入功能编号\n");
scanf("%d",&t);
switch(t)
{
case 1:
s.length=0;
printf("请输入五个数\n");
for(i = 0 ; i < 5 ; i ++)
{
printf("请输入第%d个数:",i+1);
scanf("%d",&s.data[i]);
s.length++;
}
break;
case 2:
printf("请输入插入的下标\n");
scanf("%d",&xia);
if(xia < 0 || xia >= s.length)
{
printf("下标有误\n");
}
else
{
if(s.length==N)
{
printf("顺序表满了\n");
}
else
{
printf("请输入插入的元素值:\n");
scanf("%d",&key);
for(i = s.length - 1 ; i >= xia ; i --)
{
s.data[i+1]=s.data[i];
}
s.data[xia]=key;
s.length++;
printf("插入成功\n");
}
}
break;
case 3:
printf("请输入删除的下标的数:");
scanf("%d",&xia);
if(xia < 0 || xia >= s.length)
{
printf("下标有误\n");
}
else
{
if(s.length==0)
{
printf("顺序表为空\n");
}
else
{
for(i = xia ;i <s.length - 1 ; i++)
{
s.data[i]=s.data[i+1];
}
s.length--;
printf("删除成功\n");
}
}
break;
case 4:
printf("输出所有的数\n");
for(i = 0 ; i < s.length ; i ++)
{
printf(" %d",s.data[i]);
}
printf("\n");
break;
case 0:
exit(0);
default:
printf("编号有误\n");
}
}
}