选女婿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>
int main()
{
	int n, i, j, t, height[110];
	int a, b, count = 0;
	char name[110][100], str3[110];
	scanf("%d", &n);
	for(i=0; i<n; i++)
	{
		scanf("%s %d", name[i], &height[i]);
	}
	scanf("%d %d", &a, &b);

	for(i=0; i<n-1; i++)
	   for(j=i+1; j<n ;j++)
			if(height[i]>height[j])
			{
				strcpy(str3, name[i]);
				strcpy(name[i], name[j]);
				strcpy(name[j], str3);

				t = height[i];
				height[i] = height[j];
				height[j] = t;
			}

	for(i=0; i<n; i++)
	{
		if(height[i]>=a && height[i]<=b)
		{
		    printf("%s %d
", name[i], height[i]);
		    count++;
		}
	}

	if(count==0)
		printf("No
");

return 0;
}

每天训练发现我比别人做的好慢,但是理解的更深刻,如果一开始学一个新知识点就搜模板,那么这样的人是走不远的,毕业之后带走的只有思维,什么荣誉,奖杯都已经不重要了。
原文地址:https://www.cnblogs.com/6bing/p/3931319.html