线性表初级程序..有点疑问.
#define ERROR 0#define OK 1
struct STU{
char name[20];
char stuno[10];
int age;
int score;
}stu[50];
struct LIST
{
struct STU stu[50];
int length;
}L;
int printlist(struct LIST L)
{
int i;
printf("name stuno age score\n");
for(i=0;i<L.length;i++)
printf("%s %s\t%d\t%d\n", L.stu[i].name, L.stu[i].stuno,
L.stu[i].age, L.stu[i].score);
printf("\n");
}
int listinsert(struct LIST *L,int i,struct STU e)
{
struct STU *p,*q;
if (i<1||i>L->length+1) return ERROR;
q=&(L->stu[i-1]);
for(p=&L->stu[L->length-1];p>=q;--p)
*(p+1)=*p;
*q=e;
++L->length;
return OK;
}/*ListInsert Before i */
main()
{
struct STU e;
L.length=0;
strcpy(e.name,"zmofun");
strcpy(e.stuno,"100001");
e.age=80;
e.score=1000;
listinsert(&L,1,e);
printlist(L);
printf("List length now is %d.\n\n",L.length);
strcpy(e.name,"bobjin");
strcpy(e.stuno,"100002");
e.age=80;
e.score=1000;
listinsert(&L,1,e);
printlist(L);
printf("List length now is %d.\n\n",L.length);
}
1.在构建线性表时,已知结构体对象有50个,那么定义length是为什么?也没有看到length的相关赋值语句.
2.在int listinsert函数里有语句
if(i<1||i>L->length+1)
这时候length的值是多少,加1又是为了什么?
3.暂时问题只有这么多