华为OD机试 - 求最多可以派出多少支团队 - 双指针(Java 2023 B卷 100分)

news2024/10/1 17:42:32

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

一、题目描述

用数组代表每个人的能力。一个比赛活动要求参赛团队的最低能力值为N,每个团队可以由一人或者两人组成,且一个人只能参加一个团队,计算出最多可以派出多少只符合要求的队伍。

二、输入描述

第一行代表总人数,范围1-500000

第二行数组代表每个人的能力数组大小,范围1-500000。元素取值,范围1-500000

第三行数值为团队要求的最低能力值,范围1-500000

三、输出描述

最多可以派出的团队数量。

输入输出说明
3
1 1 9
8
19自己一队,输出1
5
3 1 5 7 9
8
3说明3、5组成一队, 1、7组成1队 ,9自己一队, 输出3
7
3 1 5 7 9 2 6
8
4说明3、5组成一队, 1、7组成1队, 9自己一队,2、6组成一队 输出4

四、解题思路

  1. 第一行输入总人数n;
  2. 第二行输入每个人的能力值,通过java8 Stream表达式快速拆解输入行;
  3. 再通过boxed() 装箱函数,将基本数据类型转为对象数组,方便后续倒序排序;
  4. 第三行输入最低能力值;
  5. 降序排序;
  6. 双指针获取最多可以派出的团队数量。

五、Java算法源码

package com.guor.od;

import java.util.*;

public class OdTest01 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        // 总人数
        int n = Integer.valueOf(sc.nextLine());
        // 每个人的能力数组大小
        int[] intArr = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        // boxed() 装箱函数,将基本数据类型流转换成对象流
        Integer[] arr = Arrays.stream(intArr).boxed().toArray(Integer[]::new);
        // 最低能力值
        int min = sc.nextInt();

        // 降序
        Arrays.sort(arr, Collections.reverseOrder());

        int i = 0;
        int j = n - 1;
        int total = 0;
        while (i < j) {
            if (arr[i] >= min) {
                total += 1;
                i += 1;
            } else if (arr[i] + arr[j] >= min) {
                total += 1;
                i += 1;
                j -= 1;
            } else {
                j -= 1;
            }
        }
        System.out.println(total);
    }
}

六、效果展示

1、输入

5
3 1 5 7 9
8

2、输出

3

3、说明

说明3、5组成一队, 1、7组成1队 ,9自己一队, 输出3。

在这里插入图片描述


🏆下一篇:华为OD机试 - 荒岛求生 - 栈Stack(Java 2023 B卷 100分)

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1024935.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux提权辅助工具Linux Exploit Suggester

Linux提权辅助工具Linux Exploit Suggester 1.概述2.工具使用3.已经有人二开了 1.概述 Linux Exploit Suggester是一款根据操作系统版本号自动查找相应提权脚本的工具 Linux Exploit Suggester的官方下载地址为https://github.com/PenturaLabs/Linux_Exploit_Suggester 2.工具…

Linux内核源码分析 (B.4) 深度剖析 Linux 伙伴系统的设计与实现

Linux内核源码分析 (B.4) 深度剖析 Linux 伙伴系统的设计与实现 文章目录 1\. 伙伴系统的核心数据结构2\. 到底什么是伙伴3\. 伙伴系统的内存分配原理4\. 伙伴系统的内存回收原理5\. 进入伙伴系统的前奏5.1 获取内存区域 zone 里指定的内存水位线5.2 检查 zone 中剩余内存容量…

基于Java的公务员考试资料共享平台的设计与实现

前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb;…

JavaScript中常用的输入输出语句介绍

在日常开发中&#xff0c;为了方便数据的输入和输出&#xff0c;JavaScript提供了一些常用的输入输出语句&#xff0c;具体如表1-3所示。 表1常用的输入输出语句 接下来将分别演示document.write0、console.log0和promptO的使用。 1. document.write() document.write0的输出…

mysql大数据量 分页查询优化

最近我老表问我一个面试问题&#xff0c;如果数据量很大&#xff0c;分页查询怎么优化。 个人觉得无非就是sql优化&#xff0c; 那无非就是走索引&#xff0c; 避免回表查询&#xff08;覆盖索引&#xff0c;也就是不要用select * &#xff0c;走主键索引&#xff0c;叶子节点有…

基础算法--双指针算法

双指针算法 1.基本介绍 严格的来说&#xff0c;双指针只能说是是算法中的一种技巧。 双指针指的是在遍历对象的过程中&#xff0c;不是普通的使用单个指针进行访问&#xff0c;而是使用两个相同方向&#xff08;快慢指针&#xff09;或者相反方向&#xff08;对撞指针&#…

起底交易所JPEX:传销、诈骗,网红编织的香港加密新规第一案

香港的加密之火还在萌芽&#xff0c;就被迎头浇了一桶透心凉的冷水。 9月13日&#xff0c;香港证监会罕见点名一家虚拟资产平台JPEX&#xff0c;这也是自香港加密新规后&#xff0c;首个遭到红牌警告的虚拟资产交易所。 据证监会官网内容&#xff0c;JPEX通过社交媒体网红及场外…

MySQL进阶篇3-视图和存储过程以及触发器的学习使用

视图/存储过程&#xff08;函数&#xff09;/触发器 视图&#xff1a;由表动态生成&#xff0c;虚拟的表&#xff0c;保存的是sql的逻辑。 创建视图&#xff1a; ​ create [or replace] view viewName【列名列表】 as select 语句 [with [cascaded|local] check option] 修…

开源日报 0823 | NLP 民工的乐园:中文 NLP 资源库的终极指南

文章中介绍了几个非常有用的开源项目&#xff0c;适用于不同领域的开发者和研究者。其中&#xff0c;NLP 民工的乐园是一个非常全面的中文 NLP 资源库&#xff0c;提供了丰富的语料库、词库、词法工具和预训练语言模型&#xff0c;适用于不同的 NLP 相关任务。Poetry 是一个简化…

TOWE一转二家用无线遥控插座,让生活变得简单

随着科技的进步&#xff0c;人们的生活方式正在发生改变&#xff0c;越来越多的智能家居产品进入我们的生活中&#xff0c;为我们的生活带来了极大的便利。无线遥控插座作为一种集成了无线遥控技术与插座功能的创新产品&#xff0c;在家庭、办公、商业场景有着广泛的应用。同为…

q-learning强化学习使用基础

强化学习 通过策略的方式来学习&#xff0c;q-learing&#xff08;马尔科夫链模型&#xff09; 马尔科夫链&#xff1a;奖励*折扣因子&#xff0c;R(t)reward(1)yR(t1)&#xff0c;马尔可夫链多次迭代后分布趋于稳定所以可以得到最优解 q-learning 构建qtable&#xff0c;二…

亿发2023智能ERP生产系统解决方案实施,规范中大型企业生产精细化

随着制造水平的不断增强&#xff0c;传统工厂的管理方式已经不能满足现代制造的要求。为了确保公司战略目标的实现&#xff0c;中大型制造企业需要借助信息技术来强化对业务流程的管理&#xff0c;而生产制造ERP系统的实施已成为企业走向信息化的关键战略环节。 工厂信息化建设…

YOLOv5算法改进(19)— 更换NMS(DIoU-NMS、CIoU-NMS、EIoU-NMS、GIoU-NMS 、SIoU-NMS和Soft-NMS)

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。YOLOv5中的NMS指非极大值抑制&#xff08;Non-Maximum Suppression&#xff09;&#xff0c;它是一种用于目标检测算法中的后处理技术。在检测到多个重叠的边界框时&#xff0c;NMS可以帮助选择最佳的边界框。NMS的工作原理…

main函数中两个参数的作用

一般我们在使用C语言时不太用到main函数自带的参数&#xff0c;因此最常见的main函数就像下面这样。 int main() {...... }上面这种main函数是省略了其形参的&#xff0c;C语言中规定main函数的参数只能有两个&#xff0c;习惯上这两个参数写为argc和argv&#xff0c;其中&…

SIEM 中的事件关联

什么是 SIEM 中的事件关联 SIEM 中的事件关联可帮助安全团队识别来自不同来源的安全事件并确定其优先级&#xff0c;从而提供更全面的整体安全环境视图。 在典型的 IT 环境中&#xff0c;会跨各种系统和应用程序生成大量事件和日志。孤立地看&#xff0c;其中许多事件可能看起…

3.zigbee开发,OSAL原理及使用(类似操作系统)

一。cc2530&#xff08;zigbee的一种芯片&#xff09;使用中断 通过使用OSAL进行事件的切换&#xff0c;就是中断。 二。OSAL初步使用 1.对zigbee的工程文件进行分析&#xff08;上一节的工程模版文件&#xff09; &#xff08;1&#xff09;osal初始化&#xff1a;中断暂停…

JMeter断言之JSON断言

JSON断言 若服务器返回的Response Body为JSON格式的数据&#xff0c;使用JSON断言来判断测试结果是较好的选择。 首先需要根据JSON Path从返回的JSON数据中提取需要判断的实际结果&#xff0c;再设置预期结果&#xff0c;两者进行比较得出断言结果。 下面首先介绍JSON与JSON…

Vue模板语法集(上)

1.插值 插值&#xff1a;用双大括号{{}}将数据绑定到模板中&#xff0c;实现简单的数据渲染。例如&#xff1a;<p>{{message}}</p>&#xff0c;其中message是一个变量。 1.1.3 属性 HTML属性中的值应使用v-bind指令 1.1.4 表达式 1.1.1 文本 {{msg} 1.1.2 html 使…

HY57V561620FTP_SDRAM文档总结

文章目录 前言一、sdram简介1、名称解释2、发展历史3、与原先学习的RAM区别4、SDRAM分类 二、HY57V561620FTP1、描述1、内存划分2、特征3、引脚说明4、内部结构介绍5、交流特性6、可能涉及到的命令组合 2、SDRAM 具体操作流程1、整体状态图2、SDRAM指令及时序图3、芯片初始化(这…

​全国馆藏《乡村振兴战略下传统村落文化旅游设计》许少辉八一著作——2023学生开学季辉少许

​全国馆藏《乡村振兴战略下传统村落文化旅游设计》许少辉八一著作——2023学生开学季辉少许