#include <stdio.h>
#include <stdlib.h>
#define listsize 100
typedef struct /*建立结构体类型*/
{
long int num;
char name[20];
char gender;
int age;
}student;
typedef struct
{
student *stu;
int length;
}sqlist;
void create(sqlist *l) /*创建*/
{
int i;
printf("请输入元素个数:\n");
scanf("%d",&l->length);
printf("请输入%d个元素:\n",l->length);
for(i=0;i<l->length;i++)
scanf("%ld%s%c%d",&l->(stu+i)->num,l->(stu+i)->name,&l->(stu+i)->gender,&l->(stu+i)->age);
}
void search(sqlist *l) /*查询*/
{
student e;
int i;
printf("请输入需要查询的记录:\n");
scanf("%ld%s%c%d",&l->(e->num),l->(e->name),&l->(e->gender),&l->(e->age));
for(i=0;i<l->length;i++)
if(l->(stu+i)==e)
{
printf("这条记录在该表的第%d行。\n",i);
break;
};
if(i>=l->length) printf("此条记录不存在于该表中。\n");
}
void insert(sqlist *l) /*插入*/
{
student x;
int i,j;
printf("请输入需要插入的记录:\n");
scanf("%ld%s%c%d",&l->(x->num),l->(x->name),&l->(x->gender),&l->(x->age));
printf("请输入需要插入的位置:\n");
scanf("%d",&i);
if(l->length==listsize) printf("该表已满!\n");
for(j=l->length-1;j>=i;j--)
l->(stu+j+1)=l->(stu+j);
l->(stu+i)=x;
l->length++;
}
void delet(sqlist *l) /*删除*/
{
int i,j;
printf("请输入需要删除记录的位置:\n");
scanf("%d",&i);
if(l->length==0) printf("该表为空表!\n");
for(j=i;j<l->length-1;j++)
l->(stu+j)=l->(stu+j+1);
l->length--;
}
void main()
{
sqlist *l;
int n;
l->stu= (student *)malloc(sizeof(student));
l->length=0;
printf("-提示-\n-创建顺序表:1\n-插入记录:2\n-查询记录:3\n-删除记录:4\n请输入您要执行的操作!\n");
n=getchar();
switch(n)
{
case '1':create(l);break;
case '2':
{
if(l->length==0) printf("请先创建顺序表!\n");
else insert(l);
break;
}
case '3':
{
if(l->length==0) printf("请先创建顺序表!\n");
else search(l);
break;
}
case '4':
{
if(l->length==0) printf("请先创建顺序表!\n");
else delet(l);
break;
}
default: printf("无效输入!\n");
}
}
求改错。