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

华为OD机试 - 符合条件的元组个数 - 递归、双指针(Java 新系统 100分)

华为OD机试 新系统 题库疯狂收录中刷题点这里专栏导读本专栏收录于《华为OD机试JAVA真题》。刷的越多抽中的概率越大私信哪吒备注华为OD加入华为OD刷题交流群每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景发现新题目随时更新全天CSDN在线答疑。一、题目描述给定一个整数数组 nums一个数字k一个整数目标值 target请问nums中是否存在 k个元素使得其相加结果为target请输出所有符合条件且不重复的k元组的个数数据范围• 2 ≤ nums.length ≤ 200• -10^9 ≤ nums[i] ≤ 10^9• -10^9 ≤ target ≤ 10^9• 2 ≤ k ≤ 100二、输入描述第一行是nums取值2 7 11 15第二行是k的取值2第三行是target取值9三、输出描述输出第一行是符合要求的元组个数1补充说明[2,7]满足输出个数是1四、测试用例测试用例11、输入-1 0 1 2 -1 -4302、输出23、说明符合条件的唯一元组有 [-1, -1, 2] 和 [-1, 0, 1]所以结果是 2。测试用例21、输入2 7 11 15292、输出13、说明只有 [2, 7] 满足条件所以结果是 1。五、解题思路排序把 nums 升序排列后续可以直接跳过重复值并用双指针处理 2Sum。递归降维当 k 2 时枚举当前层的一个数 nums[i]然后在右侧区间里继续找 k-1 个数。同一层里如果 nums[i] nums[i-1]直接跳过避免重复元组。双指针终止当 k 2 时在有序数组里用左右指针统计唯一配对个数。剪枝优化当前最小可能和都大于 target后面只会更大直接 break。当前最大可能和都小于 target当前值不够大直接 continue。六、Java算法源码publicclassOdTest{publicstaticvoidmain(String[]args){ScannerscnewScanner(System.in);// 读取第一行nums 数组Stringline1readNonEmptyLine(sc);if(line1null){return;}// 读取第二行kStringline2readNonEmptyLine(sc);if(line2null){return;}// 读取第三行targetStringline3readNonEmptyLine(sc);if(line3null){return;}String[]partsline1.split(\\s);int[]numsnewint[parts.length];for(inti0;iparts.length;i){nums[i]Integer.parseInt(parts[i]);}intkInteger.parseInt(line2);longtargetLong.parseLong(line3);Arrays.sort(nums);// 前缀和prefix[i] 表示 nums[0..i-1] 的和long[]prefixnewlong[nums.length1];for(inti0;inums.length;i){prefix[i1]prefix[i]nums[i];}longanskSumCount(nums,prefix,0,k,target);System.out.println(ans);}/** * 读取非空行避免输入中有空行时出错 */privatestaticStringreadNonEmptyLine(Scannersc){while(sc.hasNextLine()){Stringlinesc.nextLine().trim();if(!line.isEmpty()){returnline;}}returnnull;}/** * 统计从 start 开始选 k 个数和为 target 的“不重复元组个数” */privatestaticlongkSumCount(int[]nums,long[]prefix,intstart,intk,longtarget){intnnums.length;// 数量不够直接无解if(n-startk){return0;}// 最底层2Sum用双指针统计唯一配对个数if(k2){returntwoSumCount(nums,start,target);}longans0;// 枚举当前层的第一个数for(intistart;in-k;i){// 同一层去重相同值只保留第一次出现的位置if(istartnums[i]nums[i-1]){continue;}// 剪枝1选 nums[i] 后后面取最小的 k-1 个数若都大于 target则后面更不可能longminPossiblenums[i]rangeSum(prefix,i1,ik);if(minPossibletarget){break;}// 剪枝2选 nums[i] 后后面取最大的 k-1 个数若都小于 target则当前 nums[i] 太小longmaxPossiblenums[i]rangeSum(prefix,n-(k-1),n);if(maxPossibletarget){continue;}// 递归去下一层找 k-1 个数anskSumCount(nums,prefix,i1,k-1,target-nums[i]);}returnans;}/** * 统计有序数组中从 start 到末尾和为 target 的唯一二元组个数 * 例如[1,1,2,2] 中 target3只统计 (1,2) 这一个“值对” */privatestaticlongtwoSumCount(int[]nums,intstart,longtarget){intlstart;intrnums.length-1;longcount0;while(lr){longsum(long)nums[l]nums[r];if(sumtarget){count;// 记录当前左右值跳过重复值保证不重复计数intleftValnums[l];intrightValnums[r];while(lrnums[l]leftVal){l;}while(lrnums[r]rightVal){r--;}}elseif(sumtarget){l;}else{r--;}}returncount;}/** * 计算前缀和区间 [l, r) 的和 */privatestaticlongrangeSum(long[]prefix,intl,intr){returnprefix[r]-prefix[l];}}七、效果展示1、输入1 2 3 431002、输出03、说明不存在 3 个数的和等于 100。下一篇华为OD机试 - 简易内存池 - 逻辑分析Java 新系统 200分本专栏收录于《华为OD机试JAVA真题》。刷的越多抽中的概率越大私信哪吒备注华为OD加入华为OD刷题交流群每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景发现新题目随时更新全天CSDN在线答疑。

相关文章:

华为OD机试 - 符合条件的元组个数 - 递归、双指针(Java 新系统 100分)

华为OD机试 新系统 题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有…...

免费降AI率哪个好?嘎嘎降AI、比话降AI、率零实测推荐

免费降AI率哪个好?嘎嘎降AI、比话降AI、率零实测推荐 “免费降AI率到底用哪个好?”——这个问题最近被问烂了。 在各种毕业论文群里、知乎上、小红书上,到处都是这个问题。答案五花八门,有推荐这个的有推荐那个的,但大…...

HiRAG:层级知识检索增强生成,小白程序员也能轻松掌握大模型技术,速收藏!

HiRAG是一种层级知识检索增强生成框架,旨在解决现有RAG方法在处理领域特定任务时面临的语义相似实体结构距离和局部与全局知识鸿沟两大挑战。通过构建多层级知识图谱和实施三层知识检索(局部、全局、桥接),HiRAG有效增强了语义关联…...

收藏!小白也能看懂:用“天才学生”培养法揭秘大模型训练全过程

本文用“培养天才学生”的比喻,将大模型训练过程分为四个阶段:博览群书(预训练)构建知识基础,教养规矩(后训练与对齐)学习人类价值观和指令理解,独立思考(推理增强&#…...

VS2022性能剖析器实战:精准测量算法的时间与内存消耗

1. 为什么需要性能剖析工具? 写算法代码时,我们经常会遇到这样的场景:代码逻辑明明正确,但运行时间就是超出限制,或者内存消耗过大导致程序崩溃。这时候就需要性能剖析工具来帮我们找出问题所在。 我最近在准备算法竞赛…...

多仪器数字电子实验箱,数字电路实验箱,电路实验箱

数字电子实验教学系统 型号:QyDE02一、实验教学系统主要特点1.实验教学系统采用主实验箱模块化的结构组合方式设计;配有实验板安装接口底座,实验板更换简便;多模块集成,支持数字电子电路系统设计与性能验证&#xff0…...

CD-HIT安装踩坑实录:从Conda到源码编译,哪种方式最适合你的Linux服务器?

CD-HIT安装踩坑实录:从Conda到源码编译,哪种方式最适合你的Linux服务器? 生物信息学工具CD-HIT作为序列去冗余的黄金标准,几乎出现在每篇涉及高通量测序分析的论文方法部分。但当你第一次在实验室服务器上尝试安装它时&#xff0c…...

避坑指南:STM32CUBEMX串口配置常见问题及解决方案(USART/printf重定向)

STM32CubeMX串口开发实战:从原理到调试的完整避坑手册 第一次在STM32CubeMX里配置串口时,我盯着那个115200的波特率数值发呆了十分钟——这个看似简单的数字背后,隐藏着多少新手会踩的坑?从时钟树配置到DMA缓冲区,从p…...

计算机视觉需要哪些数学基础?如何高效学习线性代数和概率论?

计算机视觉需要哪些数学基础?如何高效学习线性代数和概率论? 标签:#计算机视觉、#线性代数、#人工智能、#深度学习、#自然语言处理、#神经网络、#机器学习 ### 一、痛点引入:为什么很多人怕CV数学?真相是什么&#xf…...

Java的MethodHandle与反射的性能对比

Java的MethodHandle与反射的性能对比 在Java开发中,动态调用方法是一个常见的需求,而传统的反射(Reflection)和Java 7引入的MethodHandle是两种主要实现方式。虽然反射功能强大,但因其性能开销较大,Method…...

音乐魔法解密:用Spleeter实现专业级音频分离的完整指南

音乐魔法解密:用Spleeter实现专业级音频分离的完整指南 【免费下载链接】spleeter Deezer source separation library including pretrained models. 项目地址: https://gitcode.com/gh_mirrors/sp/spleeter 你是否曾梦想过拥有"音乐魔法"&#xf…...

AI Agent工作流分布式追踪实战:OpenTelemetry从黑盒到透明化的调试方案

一、背景与挑战 在构建复杂的AI Agent工作流时,你是否遇到过这样的调试困境:一个包含数据获取、多模型推理、结果整合的流程突然失败,却无法快速定位具体卡在哪一步?日志分散在各个组件,指标只能告诉你"有错误&qu…...

2026年户外广告机市场:这五大厂家正悄然改变行业格局

当你在繁华的商圈、繁忙的交通枢纽,甚至是在社区门口,看到一块块高清亮丽的屏幕,正精准地推送着各类信息时,你是否想过,支撑这些“城市之眼”背后的技术力量正在经历一场深刻的变革?2026年的户外广告机市场…...

BP神经网络交叉验证算法与确定最佳隐含层节点数Matlab程序(直接运行、数据Excel格式、...

bp神经网络交叉验证算法和确定最佳隐含层节点个数matlab 程序,直接运行即可。 数据excel格式,注释清楚,效果清晰,一步上手。BP 神经网络交叉验证与隐含层节点自寻优工具包功能说明书一、产品定位本工具包面向“零算法背景”的实验…...

SEONIB智能排期:让站点更新从偶然事件变成系统化的增长引擎

SEONIB智能排期:让站点更新从偶然事件变成系统化的增长引擎 我记得刚开始尝试用内容获取自然流量时,最困扰我的不是写不出文章,而是写出来的文章总像一场心血来潮的烟花表演——绚烂一阵,然后沉寂。我会因为一个热点,…...

Eino - ChatTemplate 的应用

Eino - ChatTemplate 的应用 前言 在 AI 应用开发中,Prompt(提示词)是与大模型交互的核心。一个好的提示词工程能够让 AI 理解任务需求并生成高质量的回复。Eino 框架提供了强大的 ChatTemplate 功能,支持模板化管理提示词、变量…...

解密昇腾ACL事件机制:如何用Event实现多Stream精准调度(避坑指南)

昇腾ACL事件机制深度解析:多Stream协同避坑实战 当你在昇腾平台上处理8路高清视频流分析时,是否遇到过这样的困境——明明硬件算力充足,但实际吞吐量却只有理论值的60%?问题的根源往往不在算法本身,而在于对ACL事件机制…...

Labelme标注数据转YOLOv5格式:手把手教你JSON转TXT(附完整代码)

Labelme标注数据转YOLOv5格式:从原理到实践的完整指南 在计算机视觉项目中,数据标注是模型训练前的关键步骤。Labelme作为一款开源的图像标注工具,因其简单易用而广受欢迎。然而,当我们需要将Labelme生成的JSON标注文件转换为YOLO…...

LeetCode --- 2293. Min Max Game 解题报告

原问题 Question: You are given a 0-indexed integer array nums whose length is a power of 2. Apply the following algorithm on nums: Let n be the length of nums. If n == 1, end the process. Otherwise, create a new 0-indexed integer array newNums of length …...

抖音批量下载技术深度解析:从单视频到用户主页的全场景解决方案

抖音批量下载技术深度解析:从单视频到用户主页的全场景解决方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallb…...

Qwen3-ForcedAligner常见问题全解析:从错误码到成功对齐

Qwen3-ForcedAligner常见问题全解析:从错误码到成功对齐 1. 为什么你的音文对齐总是失败?先理解这个核心逻辑 想象一下这个场景:你有一段清晰的会议录音,也有完整的会议纪要文字稿,现在需要把每个字在录音里的起止时…...

Qwen3-VL-8B多模态工具亲测:上传图片就能问,本地部署真简单

Qwen3-VL-8B多模态工具亲测:上传图片就能问,本地部署真简单 1. 工具概览:你的私人视觉助手 想象一下,当你看到一张复杂的图表或一张陌生的植物照片时,只需要上传图片并提问,就能立即获得专业级的解释和分…...

Diablo Edit2:终极暗黑破坏神II存档编辑器完整指南

Diablo Edit2:终极暗黑破坏神II存档编辑器完整指南 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit 还在为刷不到心仪的装备而烦恼吗?想要体验不同技能组合却不想重新练级&a…...

Windows系统下MacBook Pro Touch Bar高效解锁指南:一键开启智能触控显示功能

Windows系统下MacBook Pro Touch Bar高效解锁指南:一键开启智能触控显示功能 【免费下载链接】DFRDisplayKm Windows infrastructure support for Apple DFR (Touch Bar) 项目地址: https://gitcode.com/gh_mirrors/df/DFRDisplayKm 还在为Windows系统下MacB…...

如何在6GB显存下运行专业级AI图像生成模型

如何在6GB显存下运行专业级AI图像生成模型 【免费下载链接】flux1-dev 项目地址: https://ai.gitcode.com/hf_mirrors/Comfy-Org/flux1-dev 当大多数AI创作者还在为动辄需要24GB显存的高端显卡而烦恼时,FLUX.1-dev FP8量化模型的出现彻底改变了游戏规则。这…...

PROJECT MOGFACE创意编程项目展示:自动生成交互式网页小游戏

PROJECT MOGFACE创意编程项目展示:自动生成交互式网页小游戏 你有没有过这样的瞬间?脑子里突然蹦出一个绝妙的游戏点子,比如“一个控制小方块躲避从天而降的障碍物”,但一想到要写HTML、CSS、JavaScript,还要调试物理…...

Excel VBA 入门到精通(九):错误处理与调试

🎯 本章目标:掌握 VBA 错误处理机制,学会使用调试工具定位问题,编写健壮、可靠的代码。 一、错误类型 1.1 VBA 中的三种错误 ┌─────────────────────────────────────────────┐ │ VBA 错误类型 …...

宝塔面板如何实现网站重定向_配置301永久跳转与域名更换

宝塔面板中301重定向在网站设置页的「重定向」选项卡配置,需勾选“301永久重定向”,源目录填/实现整站跳转;路径映射复杂时须手动编辑Nginx配置文件添加rewrite规则并加permanent标志。宝塔面板里 301 重定向在哪配就在网站设置页的「重定向」…...

SQL如何检测分组内是否存在满足条件的数据_EXISTS结合分组

用 MAX(CASE WHEN condition THEN 1 ELSE 0 END) 1 判断分组内是否存在符合条件的行最稳妥,避免 EXISTS 在 GROUP BY 中语法错误或逻辑失效,兼容性好且语义清晰。GROUP BY 后怎么判断某组里有没有符合条件的行直接用 HAVING 配合聚合函数最稳妥&#xf…...

BEAST 2 贝叶斯进化分析:从新手到专家的完整指南

BEAST 2 贝叶斯进化分析:从新手到专家的完整指南 【免费下载链接】beast2 Bayesian Evolutionary Analysis by Sampling Trees 项目地址: https://gitcode.com/gh_mirrors/be/beast2 BEAST 2(Bayesian Evolutionary Analysis by Sampling Trees&a…...