向高手请教顺序表
/*顺序表a中的元素依值递增有序,将x插入其中适当位置*/#include <stdio.h>
#include <string.h>
#define OVERFLOW 0
#define LEN sizeof(struct SqList)
#define SIZE 10
typedef struct ElemType{
int num;
} ElemType;
typedef struct SqList{
ElemType *elem;
int length;
int listsize;
} Sqlist;
int Status_InsertOrderList(SqList &a, ElemType x)
{
//顺序表a中的元素依值递增有序,将x插入其中适当位置
//以保持其有序性。入口断言:0<=a.length<a.listsize
int i, j;
if (a.length == a.listsize) return (OVERFLOW);
else {
i=a.length-1;
while (i>=0 && x.num < a.elem[i]) i--; //查找x的插入位置
for(j=a.length-1;j>=i+1;j--)
a.elem[j+1]=a->elem[j]; //元素后移
a.elem[i+1]=x; //插入x
a.length++; //表长加1
return OK;
}
}
void main()
{
Sqlist *a;
int i;
ElemType *x;
a=(Sqlist*)malloc(sizeof(Sqlist));
a->elem=(ElemType*)malloc(SIZE*sizeof(ElemType)); /*开辟一个新单元*/
printf("请输入递增数列:\n");
for(i=0; i<SIZE; i++)
scanf("%d",&list->elem[i]);
printf("请输入要插入递增数列的数值:\n");
scanf("%d",&x.num);
Status_InsertOrderList(a,x);
for(i=0;i<SIZE;i++)
printf("%d ",a->elem[i]);
}
但新手我就是不知道错在哪???
请各位高手指点~谢谢~~