SDUT-ACM-选夫婿1

题目描述

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

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

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

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

输入

        潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数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,具体格式见样例。

#include<stdio.h>
int main()
{
    struct node
    {
        char name[30];
        int high;
        int wight;
    };
    struct node show[1100],put[1100],change[2];
    int a,b,c,d,i,j,k,n,m=0,t=0,t1,t2,t3;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
        scanf("%s %d %d",show[i].name,&show[i].high,&show[i].wight);
    }
    scanf("%d %d %d %d",&a,&b,&c,&d);
    for(i=0;i<n;i++)
    {
        if(a<=show[i].high && b>=show[i].high && c<=show[i].wight && show[i].wight<=d)
        {
            put[t++]=show[i];
            m=1;
        }
    }///查找符合条件元素
    for(i=0;i<t-1;i++)
    {
        for(j=0;j<t-1-i;j++)
        {
            if(put[j].high>put[j+1].high)
            {
                change[0]=put[j];
                put[j]=put[j+1];
                put[j+1]=change[0];
            }
            else if(put[j].high==put[j+1].high)
            {
                if(put[j].wight>put[j+1].wight)
                {
                    change[0]=put[j];
                    put[j]=put[j+1];
                    put[j+1]=change[0];
                }
            }
        }
    }///按身高排序
	/*for(i=0;i<t;i++)
	{
	    k=put[i].high;
	    t3=i;
	    for(j=i+1;j<t;j++)
        {
           if(k==put[j].high)
                i++;
            else
                break;
        }
        for(t1=t3;t1<i-t3;t1++)
        {
            for(t2=t3;t2<i-t3-t1;t2++)
            {
                 if(put[t2].wight>put[t2+1].wight)
                {
                    change[0]=put[t2];
                    put[t2]=put[t2+1];
                    put[t2+1]=change[0];
                }
            }
        }
	}*/
	if(m==0)
        {
            printf("No\n");
            return 0;
        }
    for(i=0;i<t;i++)
    {
        printf("%s %d %d\n",put[i].name,put[i].high,put[i].wight);
    }
    return 0;
}


这道题开始给想麻烦了,以为在排完身高后找到身高相同的区段再按体重排序。没想到在排身高的时候直接加一个按体重交换的代码,注释的一块是开始想错了的代码。做完之后感觉不难,但提交之前还是担惊受怕啊。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值