当前位置: 首页 > news >正文

阿里算法岗 0530笔试真题 - 荆棘林的最优砍断计划

荆棘林的最优砍断计划

阿里算法岗 0530笔试 第一题

题目内容

林中共有n nn株荆棘,第i ii株的坚硬度为a i a_iai,宝刀的初始锋利度为K KK。拉布可以选择任意数量的荆棘,每株至多尝试一次,并以任意顺序依次尝试砍断。每次尝试遵循以下规则:

  • 若当前锋利度K KK满足K ≥ a i K \ge a_iKai,则该荆棘被成功砍断。
  • 无论成功与否,每次尝试结束后锋利度K KK都会永久减少1 11
    拉布可以放弃任意荆棘(放弃不消耗锋利度)。请计算在最优策略下,最多能成功砍断多少株荆棘。

输入描述

每个测试文件包含多组测试数据。第一行输入一个整数T TT1 ≤ T ≤ 10 5 1 \le T \le 10^51T105)表示数据组数,每组测试数据描述如下:
每组输入一行两个整数n , K n, Kn,K1 ≤ n ≤ 2 × 10 5 1 \le n \le 2 \times 10^51n2×1051 ≤ K ≤ 10 9 1 \le K \le 10^91K109)。
接下来一行输入n nn个整数a 1 , a 2 , … , a n a_1, a_2, \dots, a_na1,a2,,an1 ≤ a i ≤ 10 9 1 \le a_i \le 10^91ai109)。
保证所有测试数据的n nn之和不超过2 × 10 5 2 \times 10^52×105

输出描述

对于每组测试数据,输出一个整数,表示在最优策略下最多能成功砍断的荆棘数量。

样例1

输入

3 5 5 2 1 4 10 3 2 1 10 10 3 3 3 3 3

输出

4 0 1

题解和思路

思路

实现思路:贪心

  1. 按照优先砍锋利度高的,能砍就砍的策略去计算数量。
  2. 将荆棘降序排序,从大到小进行扫描,如果a[i] <= k,更新ans++, k--
  3. 最终ans就是能砍的最大数量。

C++

#include<bits/stdc++.h>usingnamespacestd;intmain(){ios_base::sync_with_stdio(false);cin.tie(nullptr);intT;cin>>T;while(T--){intn,k;cin>>n>>k;vector<int>a(n);for(inti=0;i<n;i++){cin>>a[i];}// 排序sort(a.begin(),a.end());intcount=0;for(inti=n-1;i>=0;i--){// 能砍断就砍if(a[i]<=k){k--;count++;}}cout<<count<<endl;}return0;}

Java

importjava.util.*;publicclassMain{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intT=sc.nextInt();while(T-->0){intn=sc.nextInt();intk=sc.nextInt();int[]a=newint[n];for(inti=0;i<n;i++){a[i]=sc.nextInt();}// 排序Arrays.sort(a);intcount=0;for(inti=n-1;i>=0;i--){// 能砍断就砍if(a[i]<=k){k--;count++;}}System.out.println(count);}sc.close();}}

python

T=int(input())for_inrange(T):n,k=map(int,input().split())a=list(map(int,input().split()))# 排序a.sort()count=0foriinrange(n-1,-1,-1):# 能砍断就砍ifa[i]<=k:k-=1count+=1print(count)print(count)

Javascript

constreadline=require('readline');constrl=readline.createInterface({input:process.stdin,output:process.stdout});constlines=[];rl.on('line',line=>{lines.push(line);});rl.on('close',()=>{letidx=0;constT=Number(lines[idx++]);for(lett=0;t<T;t++){const[n,k0]=lines[idx++].split(' ').map(Number);letk=k0;consta=lines[idx++].split(' ').map(Number);// 排序a.sort((a,b)=>a-b);letcount=0;for(leti=n-1;i>=0;i--){// 能砍断就砍if(a[i]<=k){k--;count++;}}console.log(count);}});

Go

packagemainimport("fmt""sort")funcmain(){varTintfmt.Scan(&T)forT>0{T--varn,kintfmt.Scan(&n,&k)a:=make([]int,n)fori:=0;i<n;i++{fmt.Scan(&a[i])}// 排序sort.Ints(a)count:=0fori:=n-1;i>=0;i--{// 能砍断就砍ifa[i]<=k{k--count++}}fmt.Println(count)}}
http://www.gsyq.cn/news/1494490.html

相关文章:

  • 订单量 5 万,推送 70 万+:一次 Redis Stream 积压事故后的完整处理过程
  • Paperxie|工科毕设代码卡壳?AI 代码生成一站式搞定工程项目源码
  • SAP ABAP开发实战:从GUID做主键到cl_uuid_factory的完整使用指南(含ECC兼容方案)
  • K60微控制器时钟与ADC电气特性深度解析与高可靠性设计实践
  • 深度解析pkNX:专业级宝可梦Switch游戏ROM编辑与数据随机化工具
  • NoFences:5分钟彻底告别杂乱桌面,这款免费开源神器让Windows效率翻倍
  • 2026年不做GEO优化,老板你将错失啥?
  • 2026年AI编程工具免费付费推荐榜单
  • ARM Cortex-M0+微控制器外设驱动与内存映射实战解析
  • gradle国内镜像地址
  • 企业级GB28181视频监控平台:构建统一安防系统的终极解决方案
  • 无线芯片功耗与射频性能实战解析:从数据手册到PCB设计
  • 广州服装货源怎么找?AI穿搭教学+拿货避坑指南,这个穿搭博主藏了太多干货 - 资讯纵览
  • 从零到精通:Draw.io Mermaid插件完全指南
  • i.MX53引脚配置全解析:从数据手册到硬件设计的实战指南
  • HiveWE:魔兽争霸III地图编辑器的现代化革命,让创作效率提升10倍!
  • Kinetis KL14低功耗设计实战:从电气特性到睡眠模式深度解析
  • 定制碳纤维滤芯厂家性能、定制与服务三维对比 - 起跑123
  • 甲级乙级防火玻璃门适用场所区分,规范安装要求详解
  • 微信小程序投票系统源码包:含视频上传、虚拟礼物打赏、分组PK功能
  • 图解USACO香甜的黄油题:用SPFA算法5分钟搞定牧场最短路径问题
  • 老旧厂区防爆监控改造技术指南:合规设计、选型与施工要点
  • Windows苹果触控板原生体验:mac-precision-touchpad驱动深度解析
  • Gpt-Oss-120B (Free) 开源大模型深度评测报告
  • 新开道M-EEAT-S-F:解码AI全域信任营销底层架构的诞生与产业落地 - GrowthUME
  • ControlNet v1.1 FP16模型库:28个免费AI绘图控制模型完全指南
  • 豆包AI搜索优化效果如何?实体客户真实好评揭秘 - 起跑123
  • NXP KE1xZ MCU深度解析:从Cortex-M0+内核到低功耗设计实战
  • 如何用2048游戏AI助手轻松突破高分:完整入门教程
  • 061、移动 ISP 架构总览:从 RAW 到 YUV 的完整 Pipe 拆解与数据流分析