本次编写的程序的源码文件后缀为.cpp。
闲话不多说,直接写代码。
#include<stdio.h>
#include<stdlib.h>
//定义一个函数,在函数中定义一个结构体变量,并输入数据,将这个结构体变量返回,并且在main函数接收且输出这个结构体的数据,数据自定义。
struct student//定义一个结构体
{
int id;//学生的学号
char name[20];//学生的名字
char gender[10];//学生的性别
student* p;//定义一个结构体指针
};
student* fun()//函数的返回类型一定要和返回的目标对应
{
//单链表 结构体stu一定要加上static修饰,如果不加,则结构体stu为局部变量,出了函数fun后,结构体stu分配的内存空间就被系统回收了,结构体stu内保存的内容也就不存在了。
//定义一个结构体数组并赋值
static student stu[3] =
{
{1,"郭嘉","男",&stu[1]},//前一个结构体的结构体指针成员指向后一个结构体的地址,这就是单链表,就像链条一样,前一个连接后一个。
{2,"诸葛亮","男",&stu[2]},
{3,"姜维","男",NULL},
};
return stu;//返回结构体stu的首地址
}
int main()
{
student* st= fun();
for (; st!=NULL; st=st->p)//第一种循环显示结构体内容的方式,结构体指针st指向发生改变
printf("学号:%d 名字:%s 性别:%s\n", st->id, st->name, st->gender);
st = fun();//因为结构体指针指向发生变化,所以加上这一段,使结构体指针st重新指向结构体stu
for (int i = 0; i < 3; i++)//第二种循环显示结构体内容的方式,此种方式没有改变结构体指针的指向
printf("学号:%d 名字:%s 性别:%s\n", (st + i)->id, (*(st + i)).name, st[i].gender);//三种使用方式
for (; st->id < 4&&st->id>0; st++)//第三种循环显示结构体内容的方式,结构体指针st指向同样发生改变。因为st++运算会使结构体指针指向超出结构体stu范围的地址,超出结构体stu范围后st->id的值为零,为了规避这种情况,在for循环判断条件中要加上st->id>0的条件
printf("学号:%d 名字:%s 性别:%s\n", st->id, st->name, st->gender);
system("pause");//程序暂停
return 0;
}
程序运行结果如下图