结构体的嵌套问题

问题描述:学校正在做毕设,每名老师带领5个学生,共3名老师,设计老师和学生的结构体, 在老师的结构体中包含老师的姓名和存放5个学生的数组作为成员,学生的成员有姓名和考试分数,创建数组存放三名老师,通过函数给每个老师及所带的学生赋值。最终打印老师数据以及老师所带学生数据。

定义学生结构体

cpp 复制代码
struct Student//学生结构体的定义
{
	string sname;//学生名字
	int score;//学生分数
};

定义老师结构体

cpp 复制代码
struct Teacher //老师结构体定义
{
	string tname;//老师的名字
	struct Student sArray[5];//学生数组
};

创建函数给老师及老师所带学生信息赋值

cpp 复制代码
//创建函数给老师和学生赋值
void allocateSpace(struct Teacher tArray[], int len)
{
	srand((unsigned int)time(NULL));
	
	string nameSeed = "ABCDE";
	//给老师赋值
	for (int i = 0; i < len; i++)
	{
		tArray[i].tname = "Teacher_";
		tArray[i].tname += nameSeed[i];
		//给每名老师所带的学生赋值
		for (int j = 0; j < 5; j++)
		{
			tArray[i].sArray[j].sname = "Student_";
			tArray[i].sArray[j].sname += nameSeed[j];
			int Score = rand() % 61 + 40;
			tArray[i].sArray[j].score = Score;
		}
		
	}
	

创建函数打印老师及所带学生信息

cpp 复制代码
//创建函数打印老师和所带学生信息
void printInfo(struct Teacher tArray[], int len)
{
	for (int i = 0; i < len; i++)
	{
		cout << "老师的姓名:" << tArray[i].tname << endl;
		for (int j = 0; j < 5; j++)
		{
			cout << "\t学生姓名: " << tArray[i].sArray[j].sname <<
				" 考试分数: " << tArray[i].sArray[j].score << endl;
		}
	}
}

Main函数

cpp 复制代码
int main()
{
	//1、创建三名老师的数组
	struct Teacher tArray[3];

	//2、通过函数给3名老师的信息赋值,以及给老师所带学生的信息赋值
	int len = sizeof(tArray) / sizeof(tArray[0]);
	allocateSpace(tArray, len);

	//3、通过函数打印所有老师以及所带学生的信息
	printInfo(tArray,len);

	system("pause");
	return 0;
}

总结

cpp 复制代码
#include<iostream>
#include<string>
#include<ctime>
using namespace std;

//结构体的嵌套

struct Student//学生结构体的定义
{
	string sname;//学生名字
	int score;//学生分数
};

struct Teacher //老师结构体定义
{
	string tname;//老师的名字
	struct Student sArray[5];//学生数组
};

//创建函数给老师和学生赋值
void allocateSpace(struct Teacher tArray[], int len)
{
	srand((unsigned int)time(NULL));
	
	string nameSeed = "ABCDE";
	//给老师赋值
	for (int i = 0; i < len; i++)
	{
		tArray[i].tname = "Teacher_";
		tArray[i].tname += nameSeed[i];
		//给每名老师所带的学生赋值
		for (int j = 0; j < 5; j++)
		{
			tArray[i].sArray[j].sname = "Student_";
			tArray[i].sArray[j].sname += nameSeed[j];
			int Score = rand() % 61 + 40;
			tArray[i].sArray[j].score = Score;
		}
		
	}
	
}

//创建函数打印老师和所带学生信息
void printInfo(struct Teacher tArray[], int len)
{
	for (int i = 0; i < len; i++)
	{
		cout << "老师的姓名:" << tArray[i].tname << endl;
		for (int j = 0; j < 5; j++)
		{
			cout << "\t学生姓名: " << tArray[i].sArray[j].sname <<
				" 考试分数: " << tArray[i].sArray[j].score << endl;
		}
	}
}
	

int main()
{
	//1、创建三名老师的数组
	struct Teacher tArray[3];

	//2、通过函数给3名老师的信息赋值,以及给老师所带学生的信息赋值
	int len = sizeof(tArray) / sizeof(tArray[0]);
	allocateSpace(tArray, len);

	//3、通过函数打印所有老师以及所带学生的信息
	printInfo(tArray,len);

	system("pause");
	return 0;
}
相关推荐
小志biubiu13 分钟前
【Linux】Ext系列文件系统
linux·服务器·c语言·经验分享·笔记·ubuntu·操作系统
ha204289419439 分钟前
Linux操作系统学习之---基于环形队列的生产者消费者模型(毛坯版)
linux·c++·学习
渡我白衣3 小时前
C++ 同名全局变量:当符号在链接器中“相遇”
开发语言·c++·人工智能·深度学习·microsoft·语言模型·人机交互
GilgameshJSS3 小时前
STM32H742-ARM例程32-LCD
c语言·arm开发·stm32·单片机·嵌入式硬件·计算机外设
傻童:CPU4 小时前
C语言需要掌握的基础知识点之树
c语言·1024程序员节
是那盏灯塔4 小时前
【算法】——动态规划之01背包问题
数据结构·c++·算法·动态规划
zhilin_tang5 小时前
对比select和epoll两种多路复用机制
linux·c语言·架构
迷失的walker5 小时前
【Qt C++ QSerialPort】QSerialPort fQSerialPortInfo::availablePorts() 执行报错问题解决方案
数据库·c++·qt
南方的狮子先生7 小时前
【数据结构】(C++数据结构)查找算法与排序算法详解
数据结构·c++·学习·算法·排序算法·1024程序员节
紫荆鱼7 小时前
设计模式-适配器模式(Adapter)
c++·设计模式·适配器模式