代码随想录第25天 | 组合总和||| 、 电话号码的字母组合

news2025/1/10 12:05:10

一、前言

参考文献:代码随想录

今天的还是回溯算法,主要用到了昨天的回溯组合方法和巧妙思路方法,让我们继续为算法打基础吧!

二、组合总和||| 

1、思路:

这一题和昨日的组合没啥太大区别只是遍历的范围变为了固定的1~9,所以只需要在for循环中做做手脚即可。

(1)首先还是确定返回值和参数,这里和昨天的一样,返回void,参数三个参数,组合大小,总和大小,以及开始位置

void backtracking(int k, int n, int Instart) 

(2)接着就是终止条件了,这个需要判断两个条件,以来确认是否符合要求

if (sum == n && path.size() == k) {
            result.push_back(path);
            return;
        }

长度和大小要符合要求。

(3)接着就是for循环和递归回溯了,最开始的版本是

        for (int i = Instart; i < 10; i++) {
            path.push_back(i);
            sum += i;
            backtracking(k ,n, i + 1);
            // 回溯,重新利用
            path.pop_back();
            sum -= i;
        

这里就没有涉及到剪枝的操作,而只是全部暴力递归了,然而我们发现sum>n时,就可以提前回溯了,因为后面的肯定不符合要求了。

 

        for (int i = Instart; i < 10 - (k - path.size()) + 1; i++) {
            path.push_back(i);
            sum += i;
            // 剪枝操作,只要sum大于n就可以直接剪掉了
            if (sum > n) {
                path.pop_back();
                sum -= i;
                return;
            }
            backtracking(k ,n, i + 1);
            // 回溯,重新利用
            path.pop_back();
            sum -= i;
        }

2、整体代码如下:

class Solution {
private:
    vector<int> path; // 存储单个组合
    vector<vector<int>> result; // 返回结果
    int sum; // 统计是否等于n
    void backtracking(int k, int n, int Instart) {
        if (sum == n && path.size() == k) {
            result.push_back(path);
            return;
        }
        for (int i = Instart; i < 10 - (k - path.size()) + 1; i++) {
            path.push_back(i);
            sum += i;
            // 剪枝操作,只要sum大于n就可以直接剪掉了
            if (sum > n) {
                path.pop_back();
                sum -= i;
                return;
            }
            backtracking(k ,n, i + 1);
            // 回溯,重新利用
            path.pop_back();
            sum -= i;
        }
    }
public:
    vector<vector<int>> combinationSum3(int k, int n) {
        backtracking(k, n, 1);
        return result;
    }
};

 三、电话号码的字母组合

1、思路:

这个题目,我根据我的印象做了,但是出不来,主要是对c++的STL不熟悉所以导致出不来结果,然后只能请问GPT教授了:

(1)首先这个题目也是利用回溯,即递归里面套循环,这里我们的返回值和参数如下:

void backtracking(string digits, int startI, int startJ, vector<string> s)

 其实这里面的startJ可以省略,因为他一直是从0开始的,从头开始遍历,找到组合项,digits就是需要按的按键,startI为按键的开始位置,s就是按键所对应的数字了

(2)终止条件,也很普遍,这里就不多说了

        if (path.size() == digits.size()) {
            result.push_back(path);
            return;
        }

(3)接着就是循环和递归了,这里面略微有些技巧,但是不多

for (int i = startI; i < digits.size(); i++) {
                // 判断这个按键包含数字的多少
                int digit = digits[i] - '2';
                for (int j = startJ; j < s[digit].size(); j++) {
                    path.push_back(s[digit][j]);
                    backtracking(digits, i + 1, 0, s);
                    path.pop_back();
                }
        }

 一共嵌套两层循环,第一层是按键的位置,第二层是按键包含的字母,就开始递归,回溯了。

2、整体代码如下:

class Solution {
private:
    string path;
    vector<string> result;
    
    void backtracking(string digits, int startI, int startJ, vector<string> s) {
        if (path.size() == digits.size()) {
            result.push_back(path);
            return;
        }
        for (int i = startI; i < digits.size(); i++) {
                int digit = digits[i] - '2';
                for (int j = startJ; j < s[digit].size(); j++) {
                    path.push_back(s[digit][j]);
                    backtracking(digits, i + 1, 0, s);
                    path.pop_back();
                }
        }
    }
public:
    vector<string> letterCombinations(string digits) {
        if (digits.size() == 0) {
            return result;
        }
        vector<string> s = {
            "abc",
            "def",
            "ghi",
            "jkl",
            "mno",
            "pqrs",
            "tuv",
            "wxyz"
        };
        backtracking(digits, 0, 0, s);
        return result;
    }
};

今日学习时间:1.5小时

leave message:

The boundless forest sheds its leaves shower by shower; the endless river rolls its waves hour after hour.

无边落木萧萧下,不尽长江滚滚来。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024 年高效开发的 React 生态系统

要使用 React 制作应用程序&#xff0c;需要熟悉正确的库来添加您需要的功能。例如&#xff0c;要添加某个功能&#xff08;例如身份验证或样式&#xff09;&#xff0c;您需要找到一个好的第三方库来处理它。 在这份综合指南中&#xff0c;我将向您展示我建议您在 2024 年使用…

VS2019连接MySQL

VS2019连接MySQL 下载MySQL Connector/C配置头文件&#xff0c;库文件路径配置头文件路径配置库的路径复制dll文件 MySQL的用户设置将权限赋值给新用户 编写代码往数据库写入 老师布置的作业让我们用VS2019连接MySQL实现一个小型的日志系统&#xff0c;中间踩了很多的坑&#x…

神经网络与深度学习(一)误差反传BP算法

误差反传BP算法 1多层感知机1.1XOR问题1.2多层感知机 2.BP算法2.1简述2.2详解2.2.1输入输出模型2.2.2梯度下降算法迭代2.2.3前向传播在输出端计算误差2.2.4误差反传--输出层2.2.5误差反传--隐含层2.2.6误差反传--总结 1多层感知机 1.1XOR问题 线性不可分问题&#xff1a; 无法…

C++心决之命名空间、重载函数和引用

目录 1. C关键字(C98) 2. 命名空间 2.1 命名空间定义 2.2 命名空间使用 3. C输入&输出 4. 缺省参数 4.1 缺省参数概念 4.2 缺省参数分类 5. 函数重载 5.1 函数重载概念 5.2 C支持函数重载的原理--名字修饰(name Mangling) 6. 引用 6.1 引用概念 6.2 引用特性…

Java多线程:定位死锁

检测死锁可以使用jconsole工具&#xff0c;或使用jps定位进程id&#xff0c;再用jstack定位死锁 方案1&#xff1a; 1. 先用jps查看所有的java进程id 2. jstack 进程id定位死锁 3. 查看死锁结果 方案2:从jdk的安装路径中找到bin目录, 点击jconsole

Linux线程原理以及基础操控函数使用(1)

线程原理 这一个课程的笔记 LWP&#xff1a;light weight process 轻量级的进程&#xff0c;本质仍是进程(在Linux环境下) 进程&#xff1a;独立地址空间&#xff0c;拥有PCB 线程&#xff1a;有独立的PCB&#xff0c;但没有独立的地址空间(共享) 区别&#xff1a;在于是否共…

算法6.4-6.6DFS

一个不知名大学生&#xff0c;江湖人称菜狗 original author: Jacky Li Email : 3435673055qq.com Time of completion&#xff1a;2024.03.27 Last edited: 2024.03.27 目录 算法6.4-6.6DFS 第1关&#xff1a;算法6.5采用邻接矩阵表示图的深搜 任务描述 相关知识 编程要求…

数据结构——优先级队列及多服务台模拟系统的实现

一、优先级队列的定义和存储 优先级队列定义&#xff1a;优先级高的元素在队头&#xff0c;优先级低的元素在队尾 基于普通线性表实现优先级队列&#xff0c;入队和出队中必有一个时间复杂度O(n),基于二叉树结构实现优先级队列&#xff0c;能够让入队和出队时间复杂度都为O(log…

RabbitMQ--04--发布订阅模式 (fanout)-案例

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 发布订阅模式 (fanout)---案例前言RabbitListener和RabbitHandler的使用 1.通过Spring官网快速创建一个RabbitMQ的生产者项目2.导入项目后在application.yml文件中配…

Python编程-并发编程基础梳理与高级特性案例讲解

Python编程-并发编程基础梳理与高级特性案例讲解 同步、异步通信与IO阻塞 同步&#xff08;Synchronous&#xff09;和异步&#xff08;Asynchronous&#xff09;通信是两种不同的通信方式&#xff0c;涉及到处理任务的时序和相互等待的关系。同步通信简单直观&#xff0c;但可…

Unity 使用TrailRenderer制作拖尾效果

使用TrailRenderer实现拖尾效果&#xff0c;具体操作步骤如下&#xff1a; 1、创建一个空对象 在Unity场景中创建一个空对象 2、添加TrailRenderer组件 选择步骤1创建的空对象&#xff0c;然后在Inspector面板中点击“Add Component”按钮&#xff0c;搜索并添加TrailRende…

蓝桥杯第七届大学B组详解

目录 1.煤球数量&#xff1b; 2.生日蜡烛&#xff1b; 3.凑算式 4.方格填数 5.四平方和 6.交换瓶子 7.最大比例 1.煤球数量 题目解析&#xff1a;可以根据题目的意思&#xff0c;找到规律。 1 *- 1个 2 *** 3个 3 ****** 6个 4 ********** 10个 不难发现 第…

C++入门知识详细讲解

C入门知识详细讲解 1. C简介1.1 什么是C1.2 C的发展史1.3. C的重要性1.3.1 语言的使用广泛度1.3.2 在工作领域 2. C基本语法知识2.1. C关键字(C98)2.2. 命名空间2.2 命名空间使用2.2 命名空间使用 2.3. C输入&输出2.4. 缺省参数2.4.1 缺省参数概念2.4.2 缺省参数分类 2.5. …

Linux - 第三节

改变用户类型 su 仅单纯的进行身份变化 依旧处于普通用户里面 su - 进行重新登录更改身份 退出用exit / ctrld su 用户名 改成成其他身份 对一条命令进行提权 sudo command r:可读 w:可写 x:可执行 -:对应的权限位置&#xff0c;没有权限 去掉所有权限 chmod u…

Qt中继承QCheckBox的类结合QTableWidget实现多选并且每个多选的id都不一样

1.相关描述 继承QCheckBox的类MyCheckBox&#xff0c;利用QTableWidget的setCellWidget方式添加MyCheckBox类的对象 2.相关页面 3.相关代码 mycheckbox.h #ifndef MYCHECKBOX_H #define MYCHECKBOX_H#include <QCheckBox> #include <QObject>class MyCheckBox : pu…

Elvis Presley 英文阅读

Elvis Presley 官方翻译 One of the most popular American singers of thetwentieth century was Elvis Presley. He made theRock & Roll music popular around the world. He sold millions of records and made manysuccessful films, and he helped change the dir…

基于SSM医院病历管理系统

基于SSM医院病历管理系统的设计与实现 摘要 病历管理系统是医院管理系统的重要组成,在计算机技术快速发展之前&#xff0c;病人或者医生如果想记录并查看自己的健康信息是非常麻烦的&#xff0c;因为在以往病人的健康信息通常只保存在自己的病历卡或者就诊报告中&#xff0c;…

TikTok直播专线:解决出海网络问题痛点,提升商业效率

近年来&#xff0c;TikTok作为全球最受欢迎的社交媒体平台之一&#xff0c;成为商家获取商机与市场的重要平台。然而&#xff0c;尽管商家纷纷进入TikTok&#xff0c;试图借助其强大的社交网络进行产品推广和销售&#xff0c;但在TikTok平台进行直播时&#xff0c;往往会遇到网…

何时应用 RAG 与微调

充分发挥 LLM 的潜力需要在检索增强生成&#xff08;RAG&#xff09;和微调之间选择正确的技术。 让我们来看看何时对 LLM、较小的模型和预训练模型使用 RAG 与微调。我们将介绍&#xff1a; LLM 和 RAG 的简要背景RAG 相对于微调 LLM 的优势何时针对不同模型大小对 RAG 进行…

WebGIS 之 vue3+vite+ceisum

1.项目搭建node版本在16以上 1.1创建项目 npm create vite 项目名 1.2选择框架 vuejavaScript 1.3进入项目安装依赖 cd 项目名 npm install 1.4安装cesium依赖 pnpm i cesium vite-plugin-cesium 1.5修改vite.config.js文件 import { defineConfig } from vite import vue fr…