72 选夫婿

本文介绍了一个基于身高和体重筛选候选人的算法案例,通过Java实现,对输入的候选人信息进行过滤,确保符合条件的候选人能顺利进入下一轮选拔。

72 选夫婿

作者: Turbo时间限制: 1S章节: 结构体

问题描述 :

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

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

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

潘小姐把首轮根据身高体重进行选拔的任务交给了你,请输出晋级第二轮的选手信息。

输入说明 :

潘小姐给你了所有报名男生的信息。

输入数据的第一行是一个正整数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 < 300, 0 < c < d < 200)。

输出说明 :

你需要把合格的男生信息按照身高从矮到高输出,格式跟输入一样,也是每行三个信息,中间用一个空格隔开,如果身高相同则按体重从轻到重输出,若没有合格人选则输出“No”(不包括引号)。

输入范例 :

8
wudalang 70 40
ximenqing 180 70
likui 160 150
yanqing 175 69
luzhishen 180 100
wusong 180 75
xiaoquan 30 20
sunerniang 169 60
175 190 60 90
输出范例 :

yanqing 175 69
ximenqing 180 70
wusong 180 75

import java.util.*;
import java.util.stream.Collectors;

public class test_72 {
    /**
     * 72 选夫婿
     */
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        sc.nextLine();
        ArrayList<String> lists = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            lists.add(sc.nextLine().trim());
        }
        String[] conditions = sc.nextLine().trim().split(" ");
        List<String> collect = lists.stream()
                .filter(next -> getHeight(next) >= Integer.valueOf(conditions[0]) && getHeight(next) <= Integer.valueOf(conditions[1])
                        && getWeight(next) >= Integer.valueOf(conditions[2]) && getWeight(next) <= Integer.valueOf(conditions[3]))
                .collect(Collectors.toList());
        collect.sort((o1, o2) -> getHeight(o1).compareTo(getHeight(o2)) != 0 ? getHeight(o1).compareTo(getHeight(o2)) : getWeight(o1).compareTo(getWeight(o2)));
        if (collect.size() == 0) {
            System.out.println("No");
            return;
        }
        for (int i = 0; i < collect.size(); i++) {
            System.out.println(collect.get(i));
        }
        collect.forEach(item -> System.out.println(item));
    }

    private static Integer getHeight(String s) {
        //System.out.println("s = " + s + " height = " + s.substring(s.indexOf(" ") + 1, s.lastIndexOf(" ")));
        return Integer.valueOf(s.substring(s.indexOf(" ") + 1, s.lastIndexOf(" ")));
    }

    private static Integer getWeight(String s) {
        //System.out.println("s = " + s + "weight = " + s.substring(s.lastIndexOf(" ") + 1));
        return Integer.valueOf(s.substring(s.lastIndexOf(" ") + 1));
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值