#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
#include <ctime>
using namespace std;
/*设计一个英雄的结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放5名英雄。
通过冒泡排序的算法,将数组中的英雄按照年龄进行升序排序,最终打印排序后的结果。*/
struct hero
{
string name;
int age;
string sex;
};
void create_data(struct hero arr[], int len)
{
string name = "hero";
string num = "abcde";
for (int i = 0; i < len; i++)
{
arr[i].name = name + num[i];
arr[i].sex = "male";
arr[i].age = rand() % 10;
cout << arr[i].name << "\t" << arr[i].sex << "\t" << arr[i].age << endl;
}
}
void bubllesort(struct hero arr[], int len)
{
for (int i = 0; i < len - 1; 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; // temp已经是一个结构体了
}
}
}
for (int m = 0; m < len; m++)
{
cout << arr[m].name << "\t" << arr[m].sex << "\t" << arr[m].age << endl;
}
}
int main()
{
srand((unsigned int)time(NULL)); // 创建随机数
struct hero arr[5];
int len = sizeof(arr) / sizeof(arr[0]);
create_data(arr, len);
cout << "****************************" << endl;
bubllesort(arr, len);
system("pause");
return 0;
}
C++_Struct_2
最新推荐文章于 2024-09-30 07:31:33 发布