C 选夫婿2 SDUT

Time Limit: 1000 ms Memory Limit: 32768 KiB


Problem Description

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

在这里插入图片描述

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

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

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


Input

潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数N(0 < N < 100)。然后N行数据,每行包含两部分,用空格隔开。第一部分是报名者的姓名name(长度小于20的字符串),然后是整数身高h(0 < h < 300)。最后一行是两个整数a,b.表示身高的合格范围是[a,b]。


Output

你需要把合格的男生信息按照身高从低到高输出,格式跟输入一样,也是每行两个信息,共N行,若没有合格人选则输出No,具体格式见样例。


Sample Input

8
武大郎 70
西门庆 182
李逵 160
燕青 175
鲁智深 195
武松 180
小泉纯一狼 30
孙二娘 169
165 190


Sample Output

孙二娘 169
燕青 175
武松 180
西门庆 182


Hint

Source


#include <stdio.h>
#include <stdlib.h>
struct node
{
    char name[22];
    int height;
    int weight;
}a[1001],t;

void putin(struct node a[],int n);//输入函数;
void sorting(struct node a[],int n);//排序函数;
void putout(struct node a[],int n,int height_min,int height_max);//输出函数;


int main()
{
    int n;
    scanf("%d",&n);
    putin(a,n);
    int height_min,height_max;
    scanf("%d%d",&height_min,&height_max);
    sorting(a,n);
    putout(a,n,height_min,height_max);
    return 0;
}


void putin(struct node a[],int n)//输入函数;
{
    int i;
    for(i=0;i<n;i++)
        scanf("%s%d",a[i].name,&a[i].height);

}



void sorting(struct node a[],int n)//排序函数;
{
    int i,j;
    for(i=0;i<n-1;i++)
    {
        for(j=0;j<n-1-i;j++)
        {
            if(a[j].height>a[j+1].height)
            {
                t = a[j];
                a[j] = a[j+1];
                a[j+1]  = t;
            }
            else if(a[j].height==a[j+1].height)
            {
                if(a[j].weight>a[j+1].weight)
                {
                    t = a[j];
                    a[j] = a[j+1];
                    a[j+1] = t;
                }
            }
        }
    }
}



void putout(struct node a[],int n,int height_min,int height_max)//输出函数;
{
    int i,count = 0;
    for(i=0;i<n;i++)
    {
        if((a[i].height>=height_min)&&(a[i].height<=height_max))
         {
             count = 1;
             printf("%s %d\n",a[i].name,a[i].height);
         }
    }
    if(count == 0) printf("No");
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

碧羽o(* ̄▽ ̄*)ブ回雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值