山东理工大学[1595]选夫婿2
选夫婿2
Time Limit: 1000ms Memory limit: 32768K 有疑问?点这里^_^
题目描述
倾国倾城的大家闺秀潘小姐要选夫婿啦!武林中各门各派,武林外各大户人家,闻讯纷纷前来,强势围观。前来参与竞选的男生藏龙卧虎,高手云集,才子遍布,帅哥纷纭,更不乏富二代,官二代,可谓声势空前。

每个人参与竞选的帅哥除了进行一段激情洋溢的求婚演讲以外,还要报上自己姓名、身高,以及个人简历。最后再进行文武选拔,最后夺魁者方能得到潘小姐的芳心。
潘小姐不爱名利,只看人,第一关就是身高要合格,即必须在其要求的范围内,否则直接排除在外,不允许参加下一轮的选拔。
作为一个程序员,你没有钱也没有权,擅长的也就是编程了。潘小姐也发现了这一点,所以把首轮根据身高进行选拔的任务交给了你,如果完成的好,你可以直接进入下一轮选拔,你笑了。
输入
潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数N(0 < N < 100)。然后N行数据,每行包含两部分,用空格隔开。第一部分是报名者的姓名name(长度小于20的字符串),然后是整数身高h(0 < h < 300)。最后一行是两个整数a,b.表示身高的合格范围是[a,b]。
输出
你需要把合格的男生信息按照身高从低到高输出,格式跟输入一样,也是每行两个信息,共N行,若没有合格人选则输出No,具体格式见样例。
示例输入
8武大郎 70西门庆 182李逵 160燕青 175鲁智深 195武松 180小泉纯一狼 30孙二娘 169165 190
示例输出
孙二娘 169燕青 175武松 180西门庆 182
#include <stdio.h>
#include <string.h>
struct peo
{
int hight;
char name[20];
}peop1[100],peop2[100];
int main()
{
int n, i,j=0,min,max,k=0,t;
char a[20];
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s %d",&peop1[i].name,&peop1[i].hight);
scanf("%d %d",&min ,&max);
for(i=0;i<n;i++)
{
if(peop1[i].hight>=min&&peop1[i].hight<=max)
{
peop2[j].hight=peop1[i].hight;
strcpy(peop2[j].name,peop1[i].name);
j++;
k++;
}
}
if(k==0)
printf("No\n");
if(k!=0)
{
for(i=0;i<k-1;i++)
for(j=0;j<k-i-1;j++)
if(peop2[j].hight>peop2[j+1].hight)
{
t=peop2[j].hight;
peop2[j].hight=peop2[j+1].hight;
peop2[j+1].hight=t;
strcpy(a,peop2[j].name);
strcpy(peop2[j].name,peop2[j+1].name);
strcpy(peop2[j+1].name,a);
}
for(i=0;i<k;i++)
printf("%s %d\n",peop2[i].name,peop2[i].hight);
}
return 0;
}
浙公网安备 33010602011771号