题目:设计一个结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放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;
}