news 2026/6/10 13:07:12

(新卷,100分)- 租车骑绿岛(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 租车骑绿岛(Java JS Python)

(新卷,100分)- 租车骑绿岛(Java & JS & Python)

题目描述

部门组织绿岛骑行团建活动。租用公共双人自行车,每辆自行车最多坐两人,最大载重M。
给出部门每个人的体重,请问最多需要租用多少双人自行车。

输入描述

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

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

  • 0<m<=200
  • 0<n<=1000000
输出描述

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

用例
输入3 4
3 2 2 1
输出3
说明
题目解析

本题需要最少的车辆,即尽可能组合出重量小于等于m的两人组。

首先,我们可以将所有人按体重升序,然后将最大体重和m比较,若最大体重大于等于m,则这个人只能一人占一辆车,车数量count++,然后将最大体重弹出,继续将剩下体重中最大的和m比较,逻辑同上,直到最大体重小于m时,停止弹出。

在剩余体重中,我们利用双指针,i指针指向最小体重,j指针指向最大体重,然后组合它们,即arr[i]+arr[j],和m比较,若小于等于m,则说明这两个人可以共享一辆车,车数量count++,然后i++,j--。如果arr[i]+arr[j]>m,则说明两个人无法共享一辆车,我们只能优先将这里车分配给较大体重的人,此时车数量count++,然后j--。

按上面逻辑移动双指针,最后可能会出现两种情况:

  • i > j 此情况下所有人均分配到了车,因此可以直接输出count作为题解
  • i === j 此情况下还有一个人未分配到车,因此需要count++,为这个人单独分配一辆车
JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); const lines = []; rl.on("line", (line) => { lines.push(line); if (lines.length === 2) { const [m, n] = lines[0].split(" ").map(Number); const arr = lines[1].split(" ").map(Number); console.log(getResult(arr, m, n)); lines.length = 0; } }); function getResult(arr, m, n) { arr.sort((a, b) => a - b); let count = 0; // while (arr.at(-1) >= m) { // count++; // arr.pop(); // } let i = 0; let j = arr.length - 1; while (i < j) { if (arr[i] + arr[j] <= m) i++; j--; count++; } if (i === j) count++; return count; }
Java算法源码
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int m = sc.nextInt(); int n = sc.nextInt(); int[] arr = new int[n]; for (int i = 0; i < n; i++) { arr[i] = sc.nextInt(); } System.out.println(getResult(arr, m)); } public static int getResult(int[] arr, int m) { Arrays.sort(arr); int count = 0; int i = 0; int j = arr.length - 1; while (i < j) { if (arr[i] + arr[j] <= m) i++; j--; count++; } if (i == j) count++; return count; } }
Python算法源码
# 输入获取 m, n = map(int, input().split()) arr = list(map(int, input().split())) # 算法入口 def getResult(arr, m, n): arr.sort() count = 0 i = 0 j = n - 1 while i < j: if arr[i] + arr[j] <= m: i += 1 j -= 1 count += 1 if i == j: count += 1 return count # 算法调用 print(getResult(arr, m, n))
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 12:33:18

PyTorch安装避坑指南:为Qwen3-8B运行环境打下坚实基础

PyTorch安装避坑指南&#xff1a;为Qwen3-8B运行环境打下坚实基础 在当前大模型快速落地的浪潮中&#xff0c;越来越多开发者希望在本地设备上部署像 Qwen3-8B 这样的中等规模语言模型。它以80亿参数实现了出色的中文理解与生成能力&#xff0c;既不像百亿级模型那样对硬件“苛…

作者头像 李华
网站建设 2026/6/9 22:41:32

ICMP协议,DNS协议,http协议流量分析

流量分析ICMP协议考点&#xff1a;flag1用tshark分析ICMP协议的数据后 &#xff0c;发现没有收获&#xff0c;可以观察每个数据的长度每个数据的长度会隐藏信息前两个数据包的长度是Zm&#xff0c;跟flag的base64编码Zmxh有相同部分&#xff0c;思路就有了提出数据长度发现有相…

作者头像 李华
网站建设 2026/6/10 0:34:13

基于PyTorch的Seed-Coder-8B-Base模型优化技巧全公开

基于PyTorch的Seed-Coder-8B-Base模型优化技巧全公开 在现代软件开发节奏日益加快的今天&#xff0c;开发者对“智能编程助手”的依赖已不再是锦上添花&#xff0c;而是提升生产力的关键一环。从自动补全函数体到生成完整的测试用例&#xff0c;AI驱动的代码生成技术正在重构编…

作者头像 李华
网站建设 2026/6/10 9:13:11

(新卷,100分)- 最大花费金额(Java JS Python C)

(新卷,100分)- 最大花费金额&#xff08;Java & JS & Python & C&#xff09;题目描述双十一众多商品进行打折销售&#xff0c;小明想购买自己心仪的一些物品&#xff0c;但由于受购买资金限制&#xff0c;所以他决定从众多心仪商品中购买三件&#xff0c;而且想尽…

作者头像 李华
网站建设 2026/6/9 4:43:10

巡逻怪物研究

巡逻怪物(PatrollingMonster) 类概述 PatrollingMonster 是一个抽象基类,用于创建具有巡逻行为的怪物,例如掠夺者(Pillager)和灾厄村民(Illager)。 核心属性 @Nullable private BlockPos patrolTarget; // 巡逻目标位置 private boolean patrolLeader; // 是否是…

作者头像 李华