结构体案例一
案例描述:学生做毕设项目,每名老师有5个学生,总共有3个老师,需求如下:
- 设计学生和老师的结构体,在老师的结构体中,有老师的姓名和一个存放了5名学生的数组作为成员
- 学生的成员有姓名、考试分数,创建数组存放3名老师,通过函数给每个老师及所带的学生赋值
- 最终打印出老师数据以及老师所带的学生数据。
#include<iostream>
#include<string>
#include<ctime>
using namespace std;
struct student
{
string sname;
int score;
};
struct teacher
{
string tname;
struct student sarr[5];
};
void fuzhi(struct teacher tarr[], int len)
{
string nameseed = "ABCDE";
for (int i = 0; i < 3; i++)
{
tarr[i].tname = "Teacher_";
tarr[i].tname += nameseed[i];
for (int j = 0; j < 5; j++)
{
tarr[i].sarr[j].sname = "Student_";
tarr[i].sarr[j].sname += nameseed[j];
int random = rand() % 101;
tarr[i].sarr[j].score = random;
}
}
}
void print(struct teacher tarr[], int len)
{
for (int i = 0; i < len; i++)
{
cout << "老师的姓名:" << tarr[i].tname << endl;
cout << endl;
for (int j = 0; j < 5; j++)
{
cout << "\t姓名:" << tarr[i].sarr[j].sname << " " << "成绩:" << tarr[i].sarr[j].score << endl;
}
cout << endl << endl;
}
}
int main()
{
srand((unsigned int)time(NULL));//随机数种子
//创建3名老师的数组
struct teacher tarr[3];
int len = sizeof(tarr) / sizeof(tarr[0]);
fuzhi(tarr, len);
print(tarr, len);
system("pause");
return 0;
}
结构体案例二
- 案例描述:设计一个英雄的结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放5名英雄。
- 通过冒泡排序的算法,讲数组中的英雄按照年龄进行升序排列,最终打印出排序后的结果。
#include<iostream>
#include<string>
using namespace std;
struct hero
{
string name;
int age;
string sex;
};
struct hero arr[5] =
{
{"刘备",23,"男"},{"关羽",22,"男"},{"张飞",20,"男"},{"赵云",21,"男"},{"貂蝉",19,"女"}
};
void bubblesort(struct hero arr[], int len)
{
for (int i = 0; i < len; i++)
{
for (int j = 0; j < len-i-1; j++)
{
if (arr[j].age > arr[j + 1].age)
{
struct hero temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
void print(struct hero arr[], int len)
{
for (int i = 0; i < len; i++)
{
cout << " " << arr[i].name <<"-" << arr[i].age <<"-" <<arr[i].sex << endl;
}
}
int main()
{
int len = sizeof(arr) / sizeof(arr[0]);
cout << "初始英雄排序:" << endl << endl;
print(arr, len);
bubblesort(arr, len);
cout << endl << endl;
cout << "对英雄的年龄进行排序之后:" << endl << endl;
print(arr, len);
cout << endl << endl;
system("pause");
return 0;
}