//已知数据有三国演义里的5名英雄,请用冒泡排序按照英雄年龄升序排列
#include<iostream>
#include<string>
using namespace std;
struct Hero
{
string name;
string sex;
int age;
};
void BubleSort(struct Hero heroArr[], int len)
{
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - i - 1; j++)
{
if (heroArr[j].age > heroArr[j + 1].age)
{
struct Hero temp = heroArr[j];
heroArr[j] = heroArr[j + 1];
heroArr[j + 1] = temp;
}
}
}
}
int main()
{
//创建5名英雄的结构体
//初始化英雄结构体
struct Hero heroArr[5]=
{
{"刘备","男",24},
{"关羽","男",23},
{"张飞","男",27},
{"貂蝉","女",19},
{"吕布","男",21}
};
//未进行排序前的输出
for (int i = 0; i < 5; i++)
{
cout << "英雄姓名:" << heroArr[i].name << " " << "英雄性别:" << heroArr[i].sex << " " << "英雄年龄:" << heroArr[i].age << endl;
}
//调用函数排序后的输出
int len = sizeof(heroArr) / sizeof(heroArr[0]);
BubleSort(heroArr,len);
cout << "排序后的输出:" << endl;
for (int i = 0; i < 5; i++)
{
cout << "英雄姓名:" << heroArr[i].name << " " << "英雄性别:" << heroArr[i].sex << " " << "英雄年龄:" << heroArr[i].age << endl;
}
system("pause");
return 0;
}
利用冒泡排序按照年龄升序输出数组中的英雄信息
最新推荐文章于 2024-04-27 15:25:53 发布