day24 回溯算法 组合

题目1:77 组合

题目链接:77 组合

题意

返回[1,n]中k个数的组合 元素不可以重复使用

回溯

回溯三部曲

1)参数和返回值   void n k

2)终止条件   叶子节点的大小为2  终止,放到数组中

3)单层递归逻辑 

代码大致流程 

代码

class Solution {
public:vector<int> path;//存放单个组合vector<vector<int>> result;//存放全部组合void backtracking(int n,int k,int startIndex){//终止条件  path中有两个元素if(path.size()==k){result.push_back(path);return;}//单层递归逻辑//遍历以startIndex开头的各个元素for(int i=startIndex;i<=n;i++){//注意这里是可以等于n的,题目给定的是左闭右闭区间path.push_back(i);backtracking(n,k,i+1);//递归path.pop_back();//回溯  有递归就有回溯,且回溯在递归的下面}}vector<vector<int>> combine(int n, int k) {backtracking(n,k,1);return result;}
};
  • 时间复杂度: O(n * 2^n)
  • 空间复杂度: O(n)

剪枝

代码

class Solution {
public:vector<int> path;//存放单个组合vector<vector<int>> result;//存放全部组合void backtracking(int n,int k,int startIndex){//终止条件  path中有两个元素if(path.size()==k){result.push_back(path);return;}//单层递归逻辑//遍历以startIndex开头的各个元素for(int i=startIndex;i<=n-(k-path.size())+1;i++){//注意这里是可以等于n的,题目给定的是左闭右闭区间path.push_back(i);backtracking(n,k,i+1);//递归path.pop_back();//回溯  有递归就有回溯,且回溯在递归的下面}}vector<vector<int>> combine(int n, int k) {backtracking(n,k,1);return result;}
};

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

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

相关文章

23级应届生如何找java工作?

Java应届生找工作&#xff0c;不能单靠背面试题&#xff0c;更不能在简历中堆砌和找工作关系不大的校园实践经历&#xff0c;而是更要在面试中能证明自己的java相关商业项目经验。其实不少应届生Java求职者不是说没真实Java项目经验&#xff0c;而是不知道怎么挖掘&#xff0c;…

Redis主从架构、哨兵集群原理实战

1.主从架构简介 背景 单机部署简单&#xff0c;但是可靠性低&#xff0c;且不能很好利用CPU多核处理能力生产环境必须要保证高可用&#xff0c;一般不可能单机部署读写分离是可用性要求不高、性能要求较高、数据规模小的情况 目标 读写分离&#xff0c;扩展主节点的读能力&…

【加强版】小学数学出题,加减乘除混合运算,支持自定义数字,一键打印

在线预览&#xff1a;在线HTML代码预览和运行工具 - UU在线工具 复制下面代码后到该地址预览即可 注意&#xff1a;在线预览不能打印。如需打印&#xff0c;在电脑本地上新建文本文档&#xff0c;粘贴代码后保存&#xff0c;然后把文件后缀改为.html运行&#xff0c;出题点击…

力扣刷MySQL-第六弹(详细讲解)

&#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&#xff1a;力扣刷题讲解-MySQL &#x1f379;文章作者技术和水平很有限&#xff0c;如果文中出…

单页面vite打包学习

前端工程化本人真的很发怵&#xff0c;一直也没有专心去突破一下&#xff0c;都是能用就用&#xff0c;所以今天小小学习一下打包&#xff0c;先从单页面应用的vite打包开始。本文主要是一些我的大白话和有限的经验&#xff0c;如有问题望指正。 一、问题 网页要从服务器请求…

Crow:实现点击下载功能

Crow:设置网站的index.html-CSDN博客 讲述了如何完成一个最简单的网页的路由 很多网页提供了下载功能,怎么实现呢,其实也很简单。 假设网页的目录结构如图 $ tree static static ├── img │ └── goodday.jpg └── index.html //index.html <html> <body&…

近期学习文章

DNSlog在渗透测试中的实战技巧 - 网安隐藏源IP&#xff0c;提高溯源难度的几种方案 - 网安FreeBuf网络安全行业门户 【漏洞公告】某平台一个有意思的CSRF // SecTrain安全博客 浅谈Web源码泄漏-安全客 - 安全资讯平台 红队-C2 Server基础构建 - 先知社区FreeBuf网络安全行业…

力扣每日一题---1547. 切棍子的最小成本

//当我们将棍子分段之后&#xff0c;我们是不是想到了怎么组合这些棍子 //并且这些棍子有一个性质就是只能与相邻的进行组合 //暴力搜索的话复杂度很高 //在思考暴力搜索的时候&#xff0c;我们发现一个规律 //比如棍子长度1 2 1 1 2 //那么与最后一个2组合的棍子有&#xff0c…

Java毕业设计-基于ssm的网上求职招聘管理系统-第85期

获取源码资料&#xff0c;请移步从戎源码网&#xff1a;从戎源码网_专业的计算机毕业设计网站 项目介绍 基于ssm的网上求职招聘管理系统&#xff1a;前端 jsp、jquery&#xff0c;后端 springmvc、spring、mybatis&#xff0c;角色分为管理员、招聘人员、用户&#xff1b;集成…

关于大模型学习中遇到的3

来源&#xff1a;网络 Embedding模型 随着大型语言模型的发展&#xff0c;以ChatGPT为首&#xff0c;涌现了诸如ChatPDF、BingGPT、NotionAI等多种多样的应用。公众大量地将目光聚焦于生成模型的进展之快&#xff0c;却少有关注支撑许多大型语言模型应用落地的必不可少的Embed…

linux 安装nginx

介绍 官网 https://nginx.org/en/download.html 在安装nginx前首先要确认系统中安装了gcc、pcre-devel、zlib-devel、openssl-devel linux 检查是否安装过某软件包 yum -y install gcc pcre-devel zlib-devel openssl openssl-devel #下载 wget https://nginx.org/downloa…

Python实例:根据总步数计算消耗的热量值

随着人们对健康和运动的关注不断增加&#xff0c;越来越多的人开始关注自己的运动量和消耗的热量。在这个实例中&#xff0c;我们将使用Python来根据总步数计算消耗的热量值。这个实例可以帮助我们更好地理解Python中的数学计算和数据处理&#xff0c;并且让我们更清晰地了解运…