C++结构体案例

结构体案例

案例:

学校正在做毕业设计,每名老师带领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 sArray[5];
};
void allocateSpace(struct Teacher tArray[],int len)
{
       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 random = rand() % 61 + 40;
                     tArray[i].sArray[j].score =random;
              }
              
       }
}
//打印所有信息
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()
{
       //随机数种子
       srand((unsigned int)time(NULL));
       //创建3名老师的数组
       struct Teacher tArray[3];
       //通过函数给3名老师的信息赋值,并给老师带的学生信息赋值
       int len = sizeof(tArray) / sizeof(tArray[0]);
       allocateSpace(tArray, len);
       //打印所有老师
       printInfo(tArray,len);
       system("pause");
       return 0;
}

结构体案例2

案例描述:

设计一个英雄结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放5名英雄。通过冒泡排序的算法,将数组中的英雄按照年龄生序排序,最终打印排序后的结果

代码示例:

#include <iostream>
#include <string>
#include <ctime>
using namespace std;
//1.设计英雄结构体
struct Hero
{
       //姓名
       string name;
       //年龄
       int age;
       //性别
       string sex;
};
//冒泡排序 实现年龄升序排列
void bubbleSort(struct Hero heroArray[], int len)
{
       for (int i = 0; i < len - 1; i++)
       {
              for (int j = 0; j < len - i - 1; j++)
              {
                     //如果j下标的元素年龄大于j+1下标元素的年龄,交换两个元素
                     if (heroArray[j].age > heroArray[j + 1].age)
                     {
                           struct Hero temp = heroArray[j];
                           heroArray[j] = heroArray[j + 1];
                           heroArray[j + 1] = temp;
                     }
              }
       }
}
//打印排序后数组中的信息
void printHero(struct Hero heroArray[], int len)
{
       for (int i = 0; i < len; i++)
       {
              cout << "姓名:" << heroArray[i].name
                     << " 年龄:" << heroArray[i].age
                     << " 性别:" << heroArray[i].sex << endl;
       }
}
int main()
{
       
       //2.创建数组存放5名英雄
       struct Hero heroArray[5]=
       {
              {"刘备",23,"男"},
              {"关羽",22,"男"},
              {"张飞",20,"男"},
              {"赵云",21,"男"},
              {"貂蝉",19,"女"}
       };
       int len = sizeof(heroArray) / sizeof(heroArray[0]);
       cout << "排序前打印:" << endl;
       for (int i = 0; i < len; i++)
       {
              cout << "姓名:" << heroArray[i].name
                     << " 年龄:" << heroArray[i].age
                     << " 性别:" << heroArray[i].sex << endl;
       }
       //3.对数组进行排序,按照年龄进行生序排序
       bubbleSort(heroArray, len);
       cout << "排序后打印:" << endl;
       //4.将排序后的结果打印输出
       printHero(heroArray, len);
       return 0;
}
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑马金牌编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值