当前位置: 首页 > 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.jsqmd.com/news/982752/

相关文章:

  • MHY_Scanner:基于C++/Qt的跨平台游戏扫码登录解决方案架构解析
  • 从‘水球’到‘地球’:CESM模式复杂度升级全流程解析(含AMIP/CMIP测试指南)
  • 别再只盯着TPM 2.0了!从国产TPCM实战出发,聊聊可信启动的静态度量链到底怎么搭
  • 订单量 5 万,推送 70 万+:一次 Redis Stream 积压事故后的完整处理过程
  • K50微控制器模拟与通信接口电气规格深度解析与设计实践
  • 《B3928 [GESP202312 四级] 田忌赛马》
  • Paperxie|工科毕设代码卡壳?AI 代码生成一站式搞定工程项目源码
  • MCU时钟与模拟外设电气参数深度解析:从数据手册到设计实战
  • trae配置Kimi coding plan
  • SAP ABAP开发实战:从GUID做主键到cl_uuid_factory的完整使用指南(含ECC兼容方案)
  • i.MX 93 BGA封装引脚解析与高速PCB设计实战指南
  • 从16小时到5分钟:Illustrator批量替换革命性工具ReplaceItems.jsx完全指南
  • 深入解析MC68HC05BD7软件驱动ADC:从逐次逼近原理到嵌入式实践
  • UGV Rover ROS2 语音控制平台;Python 调用 ROS2三种主流方式;
  • K60微控制器时钟与ADC电气特性深度解析与高可靠性设计实践
  • 深度解析pkNX:专业级宝可梦Switch游戏ROM编辑与数据随机化工具
  • 嵌入式硬件工程师必读:Kinetis K11 MCU引脚配置与型号识别实战指南
  • 手把手复现中文对话机器人:LSTM Seq2Seq模型训练+推理全流程代码包
  • C++入门之string(一)
  • 2026年AI编程工具免费付费推荐榜单
  • i.MX 6UltraLite引脚分配与硬件设计实战指南
  • 2026年不做GEO优化,老板你将错失啥?
  • NoFences:5分钟彻底告别杂乱桌面,这款免费开源神器让Windows效率翻倍
  • gradle国内镜像地址
  • 如何在Windows上安装安卓应用?APK安装器的完整使用指南
  • ARM Cortex-M0+微控制器外设驱动与内存映射实战解析
  • 学术双审时代,paperxie 拆解论文降重与 AIGC 淡化的分层解决方案
  • 在上海回收黄金怕被坑?这五家靠谱门店精选推荐,附避坑指南 - 奢侈品回收评测
  • 如何利用BiliTools的AI视频总结功能实现3倍学习效率提升
  • 无线芯片功耗与射频性能实战解析:从数据手册到PCB设计