ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

7-259 选夫婿^_^ (15 分)

2021-03-25 19:01:07  阅读:186  来源: 互联网

标签:15 weight int bx hight len ++ 259 夫婿


7-259 选夫婿_ (15 分)

倾国倾城的大家闺秀潘小姐要选夫婿啦!武林中各门各派,武林外各大户人家,闻讯纷纷前来,强势围观。前来参与竞选的男生藏龙卧虎,高手云集,才子遍布,帅哥纷纭,更不乏富二代,官二代,可谓声势空前。

每个人参与竞选的帅哥除了进行一段激情洋溢的求婚演讲以外,还要报上自己姓名、身高和体重,以及个人简历。最后再进行文武选拔,最后夺魁者方能得到潘小姐的芳心。

潘小姐不爱名利,只看人,第一关就是身高和体重要合格,即必须在其要求的范围内,否则直接排除在外,不允许参加下一轮的选拔。

作为一个程序员,你没有钱也没有权,擅长的也就是编程了。潘小姐也发现了这一点,所以把首轮根据身高体重进行选拔的任务交给了你,如果完成的好,你可以直接进入下一轮选拔,你笑了。

输入格式:
潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数N(0 < N < 1000)。然后N行数据,每行包含三部分,用空格隔开。第一部分是报名者的姓名name(长度小于20的字符串),然后是整数身高h(0 < h < 300),第三部分是整数体重w (0 < w < 200)。

最后一行是四个整数a,b,c,d.表示身高的合格范围是[a,b],体重的合格范围是[c,d](0 < a < b < 200, 0 < c < d < 300)。

输出格式:
你需要把合格的男生信息按照身高从低到高输出,格式跟输入一样,也是每行三个信息,共N行,如果身高相同则按体重从轻到重输出,如果身高相同并且体重相同则按照输入顺序依次输出,若没有合格人选则输出NO,具体格式见样例。

输入样例:
8
武大郎 70 40
西门庆 180 70
李逵 160 150
燕青 175 69
鲁智深 180 100
武松 180 75
小泉纯一狼 30 20
孙二娘 169 60
165 190 60 90
输出样例:
孙二娘 169 60
燕青 175 69
西门庆 180 70
武松 180 75

代码

#include<iostream>
#include<string>
using namespace std;
#define x 1000

struct bx {
	string name;
	int hight;
	int weight;
};

void bubbleSort(struct bx a[], int len)
{
	for (int  i = 0; i < len - 1; i++)
		for (int j = 0; j < len - i - 1; j++)
			if (a[j].hight > a[j + 1].hight)
			{
				bx temp = a[j];
				a[j] = a[j+1];
				a[j+1] = temp;
			}
			else if (a[j].hight == a[j + 1].hight)
				if (a[j].weight>a[j+1].weight)
				{
					bx temp = a[j];
					a[j] = a[j+1];
					a[j+1] = temp;
				}

	
}
void printInfo(struct bx b[], int len)
{
	for (int i = 0; i < len; i++)
		cout << b[i].name << " " << b[i].hight << " " << b[i].weight << endl;
}

int main()
{
	int n;
	int a, b, c, d;
	bx t[x],m[x];
	cin >> n;
	for (int  i = 0; i < n; i++)
		cin >> t[i].name >> t[i].hight >> t[i].weight ;
	
	cin >> a >> b >> c >> d;

	int T = 0;

	for (int i = 0; i < n; i++)
	{
		if (t[i].hight>=a && t[i].hight<=b && t[i].weight>=c && t[i].weight <= d)
		{
			m[T].name = t[i].name;
			m[T].hight = t[i].hight;
			m[T].weight = t[i].weight;
			T++;
		}
	}

	//int len = sizeof(m);

	//cout << T << endl;

	if (T==0)
	{
		cout << "NO" << endl;

	}
	else
	{
		bubbleSort(m, T);
		printInfo(m, T);
	}

	system("pause");
	return 0;

}

标签:15,weight,int,bx,hight,len,++,259,夫婿
来源: https://blog.csdn.net/qq_43543476/article/details/115215928

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有