吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1265|回复: 3
收起左侧

[学习记录] C++,从入坑到埋了自己(四)-结构体与冒泡排序

[复制链接]
tester001 发表于 2022-7-18 11:12
练习:
设计一个英雄结构体,包括成员姓名、年龄、性别,创建结构体数组,数组中存放无名英雄
通过冒泡排序的算法,将数组中的英雄按照年龄进行升序排序,最终打印排序后的结果。

Ps:结构体数据类型在具体使用时是可以省略“struct”关键字的。
[C++] 纯文本查看 复制代码
#include<iostream>
#include<string>
using namespace std;

/*
* 设计一个英雄结构体,包括成员姓名、年龄、性别,创建结构体数组,数组中存放无名英雄
* 通过冒泡排序的算法,将数组中的英雄按照年龄进行升序排序,最终打印排序后的结果。
*/

//这是结构体数据类型
struct hero
{
	//成员变量
	//姓名
	string hName;
	//年龄
	int hAge;
	//性别
	string hSex;
};
//这是冒泡升序排序函数
void BubbleSort(hero hArr[], int length)
{
	for (int i = 0; i < length; i++)
	{
		for (int j = 0; j < length - i - 1; j++)
		{
			if (hArr[j].hAge > hArr[j + 1].hAge)
			{
				struct hero temp = hArr[j];
				hArr[j] = hArr[j + 1];
				hArr[j + 1] = temp;
			}
		}
	}
}

//这是打印输出函数
void printHero(hero hArr[], int length)
{
	for (int i = 0; i < length; i++)
	{
		cout << "第" << i+1 << "个的姓名是:" << hArr[i].hName<<"  "
			 <<"年龄是:" << hArr[i].hAge << "  "
			 <<"性别是"<<hArr[i].hSex << endl;
	}
	
}
//这是主函数
int main()
{
	//结构数据数组
	 hero heroArr[5] = {
		{"刘备", 32, "男"},
		{"关羽", 31, "男"},
		{"张飞", 30, "男"},
		{"小乔", 26, "女"},
		{"大乔", 27, "女"},
	};
	int len = sizeof(heroArr) / sizeof(heroArr[0]);
	BubbleSort(heroArr, len);
	printHero(heroArr, len);
	system("pause");
	return 0;
}

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
zhanglei1371 + 1 + 1 用心讨论,共获提升!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

tencentma 发表于 2022-7-18 12:00
代码写的倒是挺整齐的
SuperZDK 发表于 2022-7-18 17:15
楼主加油,C++倒是很久没写过了,现在还能看的懂哈哈
Albedo0 发表于 2022-7-22 17:56
哈哈 快进到学会重载小于号直接调用algorithm库的sort函数
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-12 17:23

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表