倾国倾城的大家闺秀潘小姐要选夫婿啦!武林中各门各派,武林外各大户人家,闻讯纷纷前来,强势围观。前来参与竞选的男生藏龙卧虎,高手云集,才子遍布,帅哥纷纭,更不乏富二代,官二代,可谓声势空前。
每个人参与竞选的帅哥除了进行一段激情洋溢的求婚演讲以外,还要报上自己姓名、身高和体重,以及个人简历。最后再进行文武选拔,最后夺魁者方能得到潘小姐的芳心。
潘小姐不爱名利,只看人,第一关就是身高和体重要合格,即必须在其要求的范围内,否则直接排除在外,不允许参加下一轮的选拔。
作为一个程序员,你没有钱也没有权,擅长的也就是编程了。潘小姐也发现了这一点,所以把首轮根据身高体重进行选拔的任务交给了你,如果完成的好,你可以直接进入下一轮选拔,你笑了。
输入格式:
潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数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<stdio.h>
struct nansheng{
char name[21];
int h;
int w;
};
int main()
{
int n,k=0,flag=0;
scanf("%d",&n);
nansheng s[1001],hao[1001],t;//hao[1001]是指通过身高体重标准的人放到一个数组里
for(int i=0;i<n;i++)
{
scanf("%s %d %d",&s[i].name,&s[i].h,&s[i].w);
}
int a,b,c,d;
scanf("%d %d %d %d",&a,&b,&c,&d);
for(int i=0;i<n;i++)
{
if(s[i].h>=a&&s[i].h<=b&&s[i].w>=c&&s[i].w<=d)
{
flag++;//单独记录通过标准的数目
hao[k]=s[i];
k++;
}
}
if(flag>0)
{
for(int i=0;i<flag;i++)
{
for(int j=0;j<flag-i-1;j++)
{
if(hao[j].h>hao[j+1].h)
{
t=hao[j];
hao[j]=hao[j+1];
hao[j+1]=t;
}
else if(hao[j].h==hao[j+1].h)
{
if(hao[j].w>hao[j+1].w)
{
t=hao[j];
hao[j]=hao[j+1];
hao[j+1]=t;
}
}
}
}
}
for(int i=0;i<flag;i++)
{
printf("%s %d %d\n",hao[i].name,hao[i].h,hao[i].w);
}
return 0;
}