java数据结构与算法刷题-----LeetCode77. 组合

2024-03-10 08:04

本文主要是介绍java数据结构与算法刷题-----LeetCode77. 组合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 1. 递归实现

在这里插入图片描述

解题思路
  1. 这种题只能暴力求解,枚举所有可能得组合
  2. 例如要找2个数的组合,那么就两层for循环,3个数的就3层for循环,k层就k个for循环
  3. 但是这样显然不现实,所以我们可以使用回溯的思路,利用递归,只写一层for循环,就可以实现普通方法下,k层for循环的效果。
  4. 当然,效率是一样的。但是代码实现起来,嵌套for循环可没法实现,试想k = 50,就得写50层for循环。
  1. 我们要进行k个数的组合,这些数字只能从1-n中去选。也就是从1-n中调出k个不同的数,组合起来。
  2. 第一个位置,可以选择1-n,从1开始,每个数都需要作为第1个位置的数,进行枚举
  3. 既然是穷举,如果第一个位置当前从3开始,那么第二个位置就从4开始枚举,因为前面的几个数组,一定已经在前几次第一个位置为1,2的时候就组合过了
  4. 所以,每一个位置,都要尝试可选的每一种可能。
枝剪操作
  1. 如果当前已经组合的数,和剩下可以参与组合的数,不够组合成一个长度为k的组合
  2. 例如我们k = 4,目前组合出来的是[4,8],剩下可以组合就剩下一个9了,最多组合成一个[4,8,9],根本不够4个数
  3. 遇到这种情况,就不需要继续枚举当前情况了。俗称枝剪操作。

1. 递归实现

代码:基本上是官方增加大量测试用例后,目前优化到的比较快的了。最前面4ms到9ms的,是远古时期提交的人,它们的代码,放到现在,只能跑到35ms,超越25%的人

在这里插入图片描述

  1. 这个是比较难理解的版本,没有使用经典的回溯模版(递归套for,for套递归),但是这个做法的速度更快
class Solution {List<List<Integer>> result;//保存答案int k;//用几个数来组合int n;//可以参与组合的数是[1,n]public List<List<Integer>> combine(int n, int k) {this.n=n;this.k=k;result=new ArrayList<List<Integer>>();//初始化链表,保存答案Integer[] records = new Integer[k];//每个保存一种组合,保存当前正在处理的组合traversal(0,1,records);//return result;}//row表示当前是第几个数参与组合,最多k个,简单来说就是records数组的下标//column表示[1,n]的下标,也就是限定哪些数可以参与组合:[column,n],简单来说是,当前用哪个数字参与组合//records 保存当前组合出来的数public void traversal(int row,int column,Integer[] records){if (column>n){//如果没有数可以参与组合,终止本次组合尝试return;}else if(records.length + (n-column+1)<k) {//剪枝操作,如果当前已经组合到的数,加上剩下还能参与组合的数,不够k个,说明无论如何都无法完成k个数的组合了。return;}else {//如果没啥问题,则当前数字column可以作为第row个数,参与当前的组合records[row]=column;//让column作为第row个数参与组合if (row==k-1){//如果当前组合完成后,正好k个值,说明得到一种满足条件的组合result.add(List.of(records));}else {//否则,进行下一个数字的枚举组合traversal(row+1,column+1, records);}//不可以排除后面其它数字,也可以作为第row个数字参与组合的情况。//也就是说,上面处理了用当前column作为第row个数的方案//这里处理,放弃column作为第row个数的方案,而试图继续向后找数字来作为第row个traversal(row, ++column, records);}}
}
  1. 经典回溯模版
    在这里插入图片描述
class Solution {public List<List<Integer>> combine(int n, int k) {List<List<Integer>> res = new ArrayList<>();if (k <= 0 || n < k) return res;//如果1-n根本不够k个就返回空[]ArrayList<Integer> path = new ArrayList<>();//用于保存当前组合路径dfs(n, k, 1, path, res);//从1开始组合return res;}void dfs(int n, int k, int begin, ArrayList<Integer> path, List<List<Integer>> res) {int size = path.size();if (size == k) {//如果当前path保存的正好是一个满足条件的组合res.add(new ArrayList<>(path));//将其放入结果中return;}//每一个位置,都要将能尝试的都尝试一遍for (int i = begin; i <= n - (k - size) + 1; i++) {path.add(i);//尝试当前位置放idfs(n, k, i + 1, path, res);//下一个位置的数字选择,必须从i+1开始path.removeLast();//选择不尝试当前位置放iif(path.size()+(n-begin) < k) return;//剪枝操作,如果剩下的可选数字,不够组成k个,就终止这次组合}}
}

这篇关于java数据结构与算法刷题-----LeetCode77. 组合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/793576

相关文章

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT