题目:设计一个结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放5名人员。通过冒泡排序的算法,将数组中的英雄按照年龄进行升序排序,最终打印排序后的结果。
这段代码实现了一个结构体的定义,以及使用冒泡排序对一组按照年龄进行排序,并打印排序后的结果。

在main函数中,定义了一个包含5个人员结构体的数组arr,每个英雄结构体包含姓名(name)、年龄(age)和性别(sex)。接下来,通过计算sizeof(arr)除以sizeof(hero),可以得到数组arr中元素的个数,赋值给变量len。
然后,调用bubbleSort函数,传入数组arr和元素个数len进行排序。bubbleSort函数使用嵌套的循环进行冒泡排序,比较相邻的两个元素的年龄大小,如果前一个元素的年龄大于后一个元素的年龄,则交换两个元素的位置。
最后,调用printHeros函数,传入排序后的数组arr和元素个数len进行打印。printHeros函数会依次输出每个人员的姓名、性别和年龄。
最后,通过system("pause")语句暂停程序的执行,以便查看结果。然后返回0表示程序成功结束。
//英雄结构体
struct hero
{
string name; // 英雄姓名
int age; // 英雄年龄
string sex; // 英雄性别
};
//冒泡排序
void bubbleSort(hero arr[], int len)
{
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - 1 - i; j++)
{
if (arr[j].age > arr[j + 1].age) // 按照年龄升序进行比较
{
hero temp = arr[j]; // 临时变量用于交换元素
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
//打印数组
void printHeros(hero arr[], int len)
{
for (int i = 0; i < len; i++)
{
cout << "姓名: " << arr[i].name << " 性别: " << arr[i].sex << " 年龄: " << arr[i].age << endl; // 输出英雄的姓名、性别和年龄
}
}
int main()
{
struct hero arr[5] = // 创建一个包含5个英雄结构体的数组
{
{"刘备", 23, "男"},
{"关羽", 22, "男"},
{"张飞", 20, "男"},
{"赵云", 21, "男"},
{"貂蝉", 19, "女"},
};
int len = sizeof(arr) / sizeof(hero); //获取数组元素个数
bubbleSort(arr, len); //排序
printHeros(arr, len); //打印
system("pause"); // 暂停程序的执行,以便查看结果
return 0;
}
该代码示例展示了如何在C++中定义一个包含姓名、年龄和性别的结构体,并创建一个结构体数组。接着,使用冒泡排序算法按年龄升序对数组进行排序,最后打印排序后的结果。主要涉及数据结构和排序算法的应用。
1564

被折叠的 条评论
为什么被折叠?



