news 2026/4/3 4:43:07

(新卷,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/3/31 15:23:58

小白刷题day2

1、[HBNIS2018]来题中等的吧目前暂未遇到过该类型&#xff0c;只有一个图片&#xff0c;感觉有规律根据中间空的格&#xff0c;一时间也没思路&#xff0c;在网上找了一下&#xff0c;可能是摩斯密码&#xff0c;转换为“.- .-… .–. … .- .-… .- -…”发给编码器&#xff0…

作者头像 李华
网站建设 2026/3/30 23:38:01

实习面试题-Linux 系统面试题

1.Linux 中的硬链接和软连接是什么,二者有什么区别? 2.CC 攻击是什么?什么叫 DDOS 攻击?什么是网站数据库注入? CC 攻击(CC Attack)是一种网络攻击方式。它通常是指对服务器进行大量并发请求的攻击,从而导致服务器的瘫痪。攻击者通过使用大量的机器或网络中的代理服务…

作者头像 李华
网站建设 2026/4/2 6:23:19

高效智能抢票神器:DamaiHelper自动化解决方案终极指南

高效智能抢票神器&#xff1a;DamaiHelper自动化解决方案终极指南 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 还在为抢不到心仪演出门票而烦恼吗&#xff1f;智能抢票工具DamaiHelper基于Pyt…

作者头像 李华
网站建设 2026/3/31 20:23:04

C#项目中引入Seed-Coder-8B-Base进行智能代码补全实战

C#项目中引入Seed-Coder-8B-Base进行智能代码补全实战 在现代软件开发节奏日益加快的背景下&#xff0c;C#开发者面对的不仅是业务逻辑复杂度的提升&#xff0c;还有对编码效率与质量的更高要求。尤其是在大型企业级项目中&#xff0c;重复性代码、异步编程模式、类型安全约束等…

作者头像 李华
网站建设 2026/3/21 7:37:57

APK Pure能否运行Qwen3-14B?移动端AI部署可行性分析

移动端能否运行Qwen3-14B&#xff1f;一场关于边缘AI部署的深度推演 在一台普通的安卓手机上&#xff0c;是否能本地运行一个拥有140亿参数的大语言模型&#xff1f;这个问题在过去或许会被直接否定——毕竟&#xff0c;连不少服务器都难以轻松承载如此规模的推理负载。但今天&…

作者头像 李华
网站建设 2026/4/1 16:37:02

安装包臃肿问题终结者:vLLM轻量高性能镜像

vLLM轻量高性能镜像&#xff1a;重塑大模型推理效率的底层革新 在AI应用加速落地的今天&#xff0c;一个现实问题困扰着无数工程师&#xff1a;为什么训练好的大模型一到线上就“跑不动”&#xff1f;明明参数规模和性能指标都达标&#xff0c;却在真实业务场景中遭遇高延迟、低…

作者头像 李华