华为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在线答疑。

相关推荐
我是华为OD~HR~栗栗呀28 分钟前
(华为od)21届-Python面经
java·前端·c++·python·华为od·华为·面试
无限码力2 小时前
华为OD机试双机位C卷 - 采样过滤 (C++ & Python & JAVA & JS & GO)
华为od·华为od机考·华为od机试·华为od机试双机位c卷·华为od上机考试·华为od机考真题·华为od机试-采样过滤
TrueFurina(互关互赞)2 小时前
7-4 区间水仙花数 Python程序设计-MJU实验四(编程入门•多代码实现•测试均通过)
数据结构·算法·飞书·创业创新·学习方法·远程工作·改行学it
曹文杰151903011210 小时前
2025 年大模型背景下应用统计本科 计算机方向 培养方案
python·线性代数·机器学习·学习方法
yaoh.wang12 小时前
力扣(LeetCode) 88: 合并两个有序数组 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
2501_933670791 天前
2026中专网络技术专业推荐证书
学习方法
焦糖夹心2 天前
IT领域自学方法
学习方法
大佬,救命!!!2 天前
python对应sql操作
开发语言·python·sql·学习笔记·学习方法
yaoh.wang4 天前
力扣(LeetCode) 27: 移除元素 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
yuhaiqun19894 天前
Typora 技能进阶:从会写 Markdown 到玩转配置 + 插件高效学习笔记
经验分享·笔记·python·学习·学习方法·ai编程·markdown