news 2026/4/16 9:01:23

(新卷,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/4/15 6:37:25

Wan2.2-T2V-5B模型优化技巧:提升ESP32平台上的推理效率

Wan2.2-T2V-5B模型优化技巧&#xff1a;提升ESP32平台上的推理效率 在短视频内容爆炸式增长的今天&#xff0c;用户对“输入一句话就能生成一段动画”的期待正从科幻走向现实。然而&#xff0c;大多数文本到视频&#xff08;Text-to-Video, T2V&#xff09;模型仍深陷于A100集…

作者头像 李华
网站建设 2026/4/8 19:04:54

Day 40 深度学习训练与测试的规范写法

在深度学习项目的开发中&#xff0c;随着模型复杂度的提升&#xff0c;编写结构清晰、易于维护的训练和测试代码变得至关重要。本篇笔记基于 MNIST 手写数字识别任务&#xff0c;详细解析了 PyTorch 中训练和测试流程的规范化写法。1. 核心设计理念在早期的简单脚本中&#xff…

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

python学习第七天

高阶函数 fitler : 用来过滤序列 def is_odd(n):return n % 2 1 l [1,2,3,4] g filter(is_odd,l)lambda匿名函数&#xff1a;def add(x,y):return xy# 等价于 add_lambda lambda x,y : xysorted函数&#xff1a; 指定排序规则排序 l [3,2,-5]print(sorted(l))sorted(l,keya…

作者头像 李华
网站建设 2026/4/15 10:29:08

Qwen3-32B性能实测:接近闭源模型的语言理解能力

Qwen3-32B性能实测&#xff1a;接近闭源模型的语言理解能力 在当前大语言模型&#xff08;LLM&#xff09;飞速发展的浪潮中&#xff0c;一个越来越清晰的趋势正在浮现&#xff1a;极致参数规模不再是唯一制胜法则。尽管千亿级模型不断刷新榜单记录&#xff0c;但高昂的部署成本…

作者头像 李华
网站建设 2026/4/8 6:38:40

FP8精度是什么?揭秘Stable Diffusion 3.5背后的量化技术原理

FP8精度是什么&#xff1f;揭秘Stable Diffusion 3.5背后的量化技术原理 在生成式AI的浪潮中&#xff0c;一个看似微小的技术革新——FP8精度——正悄然重塑大模型部署的边界。当Stability AI发布 stable-diffusion-3.5-fp8 镜像时&#xff0c;它不仅带来了一次性能飞跃&#x…

作者头像 李华