华为OD机试 - 租车骑绿道 - 双指针(Java 2023 B卷 100分)

目录

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

一、题目描述

部门组织绿岛骑行团建活动,租用公共双人自行车骑行,每辆自行车最多坐两人、最大载重 M。

给出部门每个人的体重,请问最多需要租用多少双人自行车。

二、输入描述

第一行两个数字 m、n,自行车限重 m,代表部门总人数 n。

第二行,n 个数字,代表每个人的体重。体重都小于等于自行车限重 m。

0<m <= 200

0 < n <= 1000000

三、输出描述

最小需要的双人自行车数量。

四、解题思路

1、输入

7 6

3 4 5 3 3 7

2、输出

4

3、说明

  1. 自行车限重7
  2. 一共6人,按照体重排序,3 3 3 4 5 7
  3. 分配自行车,3 + 3 < 7,3 + 4 = 7,5 < 7,7 =7
  4. 故,一共4台。

4、双指针算法

  1. 先排序;
  2. 如果两人体重之和小于等于 m,则租一辆双人自行车;
  3. 如果两人体重之和大于 m,则租一辆单人自行车;

五、Java算法源码

java 复制代码
/**
 * 双指针
 */
public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    String line1 = sc.nextLine();
    String line2 = sc.nextLine();
    String[] split = line1.split(" ");

    // 自行车限重 m
    int m = Integer.parseInt(split[0]);
    // 人数n
    int n = Integer.parseInt(split[1]);

    // 需要的自行车数量
    int count = 0;

    // 每个人的体重集合
    String[] arr = line2.split(" ");
    int[] nums = new int[arr.length];
    for (int i = 0; i < nums.length; i++) {
        nums[i] = Integer.parseInt(arr[i]);
    }

    // 按照体重排序
    Arrays.sort(nums);

    // 体重最轻的人
    int i = 0;
    // 体重最重的人
    int j = nums.length - 1;
    /**
     * 如果两人体重之和小于等于 m,则租一辆双人自行车。
     * 如果两人体重之和大于 m,则租一辆单人自行车。
     */
    while (i < j) {
        // 如果两个重量加起来大于m,那么右指针左移
        if (nums[i] + nums[j] > m) {
            j--;
            count++;
        } else {
            i++;
            j--;
            count++;
        }
    }
    // 左右指针相等时
    if (i == j) {
        count++;
    }
    System.out.println(count);
}

六、效果展示

🏆下一篇:华为OD机试真题 Java 实现【简易内存池】【2023 B卷 200分 考生抽中题】

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

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

相关推荐
lkbhua莱克瓦2415 小时前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
uesowys15 小时前
华为OD算法开发指导-简易内存池
java·算法·华为od
闭着眼睛学算法21 小时前
【双机位A卷】华为OD笔试之【哈希表】双机位A-采购订单【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·华为od·散列表
武陵悭臾1 天前
Python应用开发学习: Pygame 中实现数字水平靠右对齐和垂直靠底对齐
python·学习·程序人生·游戏·个人开发·学习方法·pygame
01100001乄夵1 天前
第二课:时序逻辑入门-零基础FPGA闯关教程
经验分享·笔记·学习方法
小龙报1 天前
算法通关指南:数据结构和算法篇 --- 队列相关算法题》--- 1. 【模板】队列,2. 机器翻译
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
洛白白2 天前
“职场心态与心穷
经验分享·学习·生活·学习方法
小龙报2 天前
《算法通关指南数据结构和算法篇(4)--- 队列和queue》
c语言·开发语言·数据结构·c++·创业创新·学习方法·visual studio
秦明月133 天前
EPLAN电气设计:快捷键版本差异解析
经验分享·学习·学习方法·设计规范
小龙报3 天前
《C语言疑难点 --- C语内存函数专题》
c语言·开发语言·c++·创业创新·学习方法·业界资讯·visual studio