|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
===========================仅供研究,老鸟勿喷!===========
# include <stdio.h>
# include <malloc.h>
//==========函数声明===============
void shuchu(struct stu *);
struct stu * luru(void);
//==========结构体=================
struct stu
{
int num;
char name[8];
float cj;
struct stu *pn;
};
//=========main函数================
int main(void)
{
struct stu *pst;
pst = luru();
shuchu(pst);
return 0;
}
//=========数据录入====================
struct stu * luru(void)
{
struct stu *p1;
struct stu *pst = (struct stu *)malloc(sizeof(struct stu)); //创建一个动态结构体
p1=pst;
p1->pn = NULL; //使结构体中的结构体指针为空
struct stu *news;
do
{
news = (struct stu *)malloc(sizeof(struct stu)); //创建要被录入的链表中第一个结构体
printf("请输入学号:\n");
scanf("%d",&news->num );
if( news->num ) //如果输入学号为0 则退出循环
{
printf("请输入姓名:\n"); //录入部分
scanf("%s",news->name );
printf("请输入成绩:\n");
scanf("%f",&news->cj );
p1->pn = news; //将结构体中的指针指向下一个结构体
news->pn=NULL;
p1 = news;
}
}while ( news->num );
return pst; //返回第一个结构体的指针
}
//============数据输出===================
void shuchu(struct stu *pst)
{
while( pst->pn!=NULL ) //输出录入结果,直到结构体中的指针为NULL
{
pst=pst->pn;
printf("学号:%10d 姓名:%10s 成绩:%10f\n",pst->num,pst->name,pst->cj);
}
return;
}
|
|