主题:请高手看看错误的原因【急】
代码如下:
#include <stdio.h>
#include <stdlib.h>
typedef struct student
{
long stuid;
char name[10];
long phoneNo;
struct student *next;
}LStu,*Stulist;
//建立一个学生信息
Stulist creatStu()
{
Stulist s;
s = (Stulist)malloc ( sizeof(LStu) );
if(!s)
{
printf("存储分配失败!\n");
exit(0);
}
printf("请输入学生的学号:\n");
scanf("%ld",&(s->stuid));
printf("请输入学生的姓名:\n");
scanf("%s",s->name);
printf("请输入学生的电话号码:\n");
scanf("%ld",&(s->phoneNo));
// printf("%s\n",s->name);
// printf("%ld\n",s->phoneNo);
// printf("%ld\n",s->stuid);
return s;
}
//初始化链表
void initList(Stulist *L)
{
Stulist s;
(*L) = NULL;
s = (Stulist)malloc ( sizeof(LStu) );
s->next = (*L);
(*L) = s;
printf("链表已创建...\n");
}
//创建链表
void createList(Stulist *L)
{
int i = 1;
int j = 1;
initList(L);
printf("现在需要添加学生信息吗?(1.是/0.否)\n");
scanf("%d",&i);
while(i)
{
insertElement((*L),j);
j++;
printf("继续吗?(1.是/0.否)\n");
scanf("%d",&i);
}
}
//向链表中插入元素
int insertElement(Stulist L,int i)
{
Stulist p,s;
int j = 0;
p = L;
s = creatStu();
while (p && j < i-1)
{
p = p->next;
++j;
}
if(!p||j>i-1)
{
printf("插入位置有错!\n");
return 0;
}
s->next = p->next;
p->next = s;
return 1;
}
//输出指定元素信息
void printInfor(Stulist L,int i)
{
Stulist s = NULL;
s = getElementAt(L,i);
if(!s) return;
printf("学号:%ld",s->stuid);
printf(",姓名:%s",s->name);
printf(",电话:%ld\n",s->phoneNo);
}
//获得指定位置的元素
Stulist getElementAt(Stulist L,int i)
{////////////////////////////////////////////////报告说这句有错
Stulist p = NULL;
int j = 1;
p = L->next;
while (p && j<i)
{
p = p->next;
++j;
}
if(!p||j>i)
{
printf("所给位置有错!\n");
return NULL;
}
/* printf("学号:%ld",p->stuid);
printf(",姓名:%s",p->name);
printf(",电话:%ld\n",p->phoneNo);*/
return p;
}
//主函数
void main()
{
int i = 1,location;
Stulist L;
while(i)
{
printf("请选择:\n");
printf("1.建立链表 2.删除元素 3.插入元素 4.输出元素 5.显示全部 0.退出\n");
scanf("%d",&i);
switch(i)
{
case 1: createList(&L);
break;
case 2:
break;
case 3:
break;
case 4: printf("请输入要输出元素的位置.\n");
scanf("%d",&location);
getElementAt(L,location);
break;
case 5: break;
}
}
}
错误信息:
c:\documents and settings\owner\桌面\program\数据结构\错误\error1.c(99) : error C2040: 'getElementAt' : 'struct student *(struct student *,int )' differs in levels of indirection from 'int ()'
c:\documents and settings\owner\桌面\program\数据结构\错误\error1.c(90) : warning C4047: '=' : 'struct student *' differs in levels of indirection from 'int '
#include <stdio.h>
#include <stdlib.h>
typedef struct student
{
long stuid;
char name[10];
long phoneNo;
struct student *next;
}LStu,*Stulist;
//建立一个学生信息
Stulist creatStu()
{
Stulist s;
s = (Stulist)malloc ( sizeof(LStu) );
if(!s)
{
printf("存储分配失败!\n");
exit(0);
}
printf("请输入学生的学号:\n");
scanf("%ld",&(s->stuid));
printf("请输入学生的姓名:\n");
scanf("%s",s->name);
printf("请输入学生的电话号码:\n");
scanf("%ld",&(s->phoneNo));
// printf("%s\n",s->name);
// printf("%ld\n",s->phoneNo);
// printf("%ld\n",s->stuid);
return s;
}
//初始化链表
void initList(Stulist *L)
{
Stulist s;
(*L) = NULL;
s = (Stulist)malloc ( sizeof(LStu) );
s->next = (*L);
(*L) = s;
printf("链表已创建...\n");
}
//创建链表
void createList(Stulist *L)
{
int i = 1;
int j = 1;
initList(L);
printf("现在需要添加学生信息吗?(1.是/0.否)\n");
scanf("%d",&i);
while(i)
{
insertElement((*L),j);
j++;
printf("继续吗?(1.是/0.否)\n");
scanf("%d",&i);
}
}
//向链表中插入元素
int insertElement(Stulist L,int i)
{
Stulist p,s;
int j = 0;
p = L;
s = creatStu();
while (p && j < i-1)
{
p = p->next;
++j;
}
if(!p||j>i-1)
{
printf("插入位置有错!\n");
return 0;
}
s->next = p->next;
p->next = s;
return 1;
}
//输出指定元素信息
void printInfor(Stulist L,int i)
{
Stulist s = NULL;
s = getElementAt(L,i);
if(!s) return;
printf("学号:%ld",s->stuid);
printf(",姓名:%s",s->name);
printf(",电话:%ld\n",s->phoneNo);
}
//获得指定位置的元素
Stulist getElementAt(Stulist L,int i)
{////////////////////////////////////////////////报告说这句有错
Stulist p = NULL;
int j = 1;
p = L->next;
while (p && j<i)
{
p = p->next;
++j;
}
if(!p||j>i)
{
printf("所给位置有错!\n");
return NULL;
}
/* printf("学号:%ld",p->stuid);
printf(",姓名:%s",p->name);
printf(",电话:%ld\n",p->phoneNo);*/
return p;
}
//主函数
void main()
{
int i = 1,location;
Stulist L;
while(i)
{
printf("请选择:\n");
printf("1.建立链表 2.删除元素 3.插入元素 4.输出元素 5.显示全部 0.退出\n");
scanf("%d",&i);
switch(i)
{
case 1: createList(&L);
break;
case 2:
break;
case 3:
break;
case 4: printf("请输入要输出元素的位置.\n");
scanf("%d",&location);
getElementAt(L,location);
break;
case 5: break;
}
}
}
错误信息:
c:\documents and settings\owner\桌面\program\数据结构\错误\error1.c(99) : error C2040: 'getElementAt' : 'struct student *(struct student *,int )' differs in levels of indirection from 'int ()'
c:\documents and settings\owner\桌面\program\数据结构\错误\error1.c(90) : warning C4047: '=' : 'struct student *' differs in levels of indirection from 'int '