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

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

猜你喜欢

转载自blog.csdn.net/dsafefvf/article/details/131405257
今日推荐