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个,就终止这次组合}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/526466.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软文发布被拒稿的5大原因,如何避免?

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 软文发布被拒稿是许多企业和个人在推广过程中常常遇到的问题。了解拒稿的原因并学会如何避免&#xff0c;可以显著提高软文的发布成功率。下面我们将针对五个常见原因进行分析&#xff0…

深入理解 Vuex:从基础到应用场景

前言 在之前的文章中&#xff0c;我们已经对 Vue.js 有了一定的了解。今天我们要对Vue官方的状态共享管理器Vuex进行详细讲解&#xff0c;将其基本吃透&#xff0c;目标是面对大多数业务需求&#xff1b; 一、介绍 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用…

ACK的Java应用POD无法访问云数据库Redis

问题介绍 如下图所示&#xff0c;是ACK集群的POD访问阿里云的云数据库Redis&#xff0c;如何实现访问呢 配置步骤 要实现ACK集群内的所有POD都可以访问云数据库Redis&#xff0c;则需要在Redsi的白名单里增加源IP或网段&#xff0c;如下图所示 注意&#xff1a; 以上添加…

LeetCode每日一题之 除自身以外数组的乘积

目录 题目介绍&#xff1a; 算法原理&#xff1a; 特殊位置处理&#xff1a; 代码实现&#xff1a; 题目介绍&#xff1a; 题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 算法原理&#xff1a; 这道题其实和我上一道题非常相似---寻找数组的中心下标&am…

AHU 数据库 实验五

【实验名称】 实验5 数据库的数据更新与视图管理 【实验目的】 1. 熟悉数据更新操作的概念与操作类型&#xff1b; 2. 熟练掌握INSERT、UPDATE、DELETE语句的基本语法&#xff1b; 3. 熟练运用INSERT、UPDATE、DELETE语句实现数据的插入、修改与删除…

[备赛笔记]——5G大唐杯(5G考试等级考考试基础试题)

个人名片&#xff1a; &#x1f981;作者简介&#xff1a;学生 &#x1f42f;个人主页&#xff1a;妄北y &#x1f427;个人QQ&#xff1a;2061314755 &#x1f43b;个人邮箱&#xff1a;2061314755qq.com &#x1f989;个人WeChat&#xff1a;Vir2021GKBS &#x1f43c;本文由…

【JavaScript 漫游】【033】Cookie 总结

文章简介 本篇文章为【JavaScript 漫游】专栏的第 033 篇文章&#xff0c;主要记录了浏览器模型中 Cookie 相关的知识点。 Cookie 概述 Cookie 是服务器保存在浏览器的一小段文本信息&#xff0c;一般大小不能超过4KB。浏览器每次向服务器发出请求&#xff0c;就会自动附上这…

NASA数据集——ICESat-2 ATL03(ATL03A/ATL03G)经纬度和海拔高度数据集下载

简介 ICESat-2 为科学家们提供了高度测量数据,从而绘制出地球三维的全球肖像,收集的数据可以精确跟踪包括冰川、海冰、森林等在内的地形变化。 虽然 ICESat-2 的许多发现尚待想象,但该卫星任务有四个科学目标: 测量融化的冰原并研究其对海平面上升的影响、测量和研究冰原…

GO语言接入支付宝

GO语言接入支付宝 今天就go语言接入支付宝写一个教程 使用如下库&#xff0c;各种接口较为齐全 "github.com/smartwalle/alipay/v3"先简单介绍下加密&#xff1a; 试想&#xff0c;当用户向支付宝付款时&#xff0c;若不进行任何加密&#xff0c;那么黑客就可以任…

Ubuntu18.04 下使用 Pybind11实现 C++ 调用 Python 函数和类的示例

Pybind11 是一个轻量级的库&#xff0c;它提供了在 C 中无缝集成 Python 代码的能力。使用 Pybind11&#xff0c;你可以很容易地从 C 调用 Python 代码&#xff0c;反之亦然。下面我将通过一个简单的例子来展示如何在 Ubuntu 系统上使用 Pybind11 从 C 调用 Python 接口。 安装…

day15_集合_ArrayList

今日内容 零、 复习昨日 一、集合框架体系 二、Collection 三、泛型 四、迭代 五、List(ArrayList、LinkedList) 零、 复习昨日 日期解析的方法签名(字符串–>日期) Date parse(String s) 日期格式化的方法签名(日期–>字符串) String format(Date date) 运行时异常有哪些…

ROS2中launch编写及参数含义(xml、python)

ROS2系列文章目录 ROS2中nav_msgs/msg/Path 数据含义及使用 ROS2中std_msgs/msg/Header 数据含义及使用 ROS中TF变换详解 文章目录 ROS2系列文章目录ROS2中launch编写及参数含义&#xff08;xml、python&#xff09;一、ROS官方介绍二、实现案例1.编写主函数、CMakeLists.tx…