Java-华为真题-预定酒店

需求:

复制代码
   放暑假了,小王决定到某旅游景点游玩,他在网上搜索到了各种价位的酒店(长度为n的数组A),他的心理价位是x元,请帮他筛选出k个最接近x元的酒店(n>=k>0),并由低到高打印酒店的价格。
复制代码
 1)酒店价格数组A和小王的心理价位x均为整型数据;(0 < n,k,x < 10000)
复制代码
 2)优先选择价格最接近心理价位的酒店;若两家酒店和心理价位差价相同,则选择价格较低的酒店。(比如100元和300元距离心理价位200元同样接近,此时选择100元);
复制代码
3)酒店价格可能相同重复。
复制代码
输入描述:
  第一行:n, k, x
  第二行:A[0] A[1] A[2]…A[n-1]

输出描述:
  由低到高打印筛选出的酒店价格

编码:

java 复制代码
public class ReservationHotel {
    public static void main(String[] args) {
        //使用useDelimiter()方法,输入一起输入
        Scanner sc = new Scanner(System.in).useDelimiter("\\D");
        System.out.print("请输入:");
        int count=sc.nextInt();
        int number=sc.nextInt();
        int money=sc.nextInt();
        //调用方法
        show(count,number,money,sc);
    }

    /**
     *
     * @param count 数组长度
     * @param number 筛选个数
     * @param money 目标价位
     */
    public static void show(int count,int number,int money, Scanner sc ){
       //(1)集合存放各个酒店价格数据
        List<Integer> hotelPriceList = new ArrayList<>();
        System.out.print("请输入"+count+"个酒店价格:");
        for (int i = 0; i <count ; i++) {
            hotelPriceList.add(sc.nextInt());
        }
       // (2)根据酒店价格从低到高排序
        Collections.sort(hotelPriceList,(o1, o2) -> {
            //心理价位差价
            int dif1=Math.abs(o1-money);
            int dif2=Math.abs(o2-money);
//            比较不等
            if (dif1!=dif2){
                return Integer.compare(dif1,dif2);
            }else{
                return  Integer.compare(o1,o2);
            }
        });

        System.out.println("进行比较后的酒店价格:"+hotelPriceList.toString());

        //(3)将集合存放各个筛选出number个最接近money元的酒店
        List<Integer> findPriceList = new ArrayList<>();
        for (int i = 0; i <number ; i++) {
            findPriceList.add(hotelPriceList.get(i)); //获取酒店筛选出数据
        }

        //(4)再按酒店价格从低到高排序
        Collections.sort(findPriceList);

        System.out.println("筛选出最接目标价位"+money+"元的酒店:"+findPriceList.toString());
    }
}

效果:

相关推荐
Chengbei11几秒前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1126 分钟前
web-第一次课后作业
java·开发语言·idea
小熊Coding17 分钟前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋921 分钟前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本26 分钟前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
xiaoshuaishuai840 分钟前
C# 内存管理与资源泄漏
开发语言·c#
DIY源码阁1 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
lsx2024061 小时前
SVN 检出操作
开发语言
basketball6162 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
旺仔来了2 小时前
不联网的Linux下部署python环境
linux·开发语言·python