算法刷题Day27 | 39. 组合总和、40.组合总和II、131.分割回文串

news2024/11/27 14:32:08

目录

  • 0 引言
  • 1 组合总和
    • 1.1 我的解题
  • 2 组合总和II
    • 2.1 解题
  • 3 分割回文串
    • 3.1 切割
    • 3.2 总结:分割和组合的区别

请添加图片描述

  • 🙋‍♂️ 作者:海码007
  • 📜 专栏:算法专栏
  • 💥 标题:算法刷题Day27 | 39. 组合总和、40.组合总和II、131.分割回文串
  • ❣️ 寄语:书到用时方恨少,事非经过不知难!

0 引言

趁着周末赶紧追

1 组合总和

  • 🎈 文档讲解
  • 🎈 视频讲解
  • 🎈 做题状态:

1.1 我的解题

这道题其实就是可以把已经遍历的元素再遍历一次,就是改变了 firstIndex 的位置而已。逻辑和之前的题目类似。还有终止条件不太一样就是。

class Solution
{
public:
    // 1. 回溯函数参数和返回值
    void backTracing(vector<int>& candidates, int target, int firstIndex, vector<int>& path, vector<vector<int>>& paths)
    {
        // 2. 终止条件
        int sum = 0;
        for (auto data : path)
        {
            sum += data;
        }
        if (sum > target)
        {
            return;
        }
        if (sum == target)
        {
            paths.emplace_back(path);
            return;
        }

        // 3. 单层回溯逻辑
        for (int i = firstIndex; i < candidates.size(); i++)
        {
            path.emplace_back(candidates[i]);
            backTracing(candidates, target, i, path, paths);
            path.pop_back();
        }
    }

    vector<vector<int>> combinationSum(vector<int>& candidates, int target) 
    {
        vector<vector<int>> paths;
        vector<int> path;
        backTracing(candidates, target, 0, path, paths);
        return paths;
    }

};

2 组合总和II

  • 🎈 文档讲解
  • 🎈 视频讲解
  • 🎈 做题状态:

2.1 解题

这道题注意了,集合中不能有重复的。上一道题简单的改变 firstIndex 就可以避免重复的组合是因为,给出的集合中本身不含有重复的数字。但是这道题中是包含重复数字的。

这道题比较难,理解关键点在于 去重:树层去重、树枝去重。

那么如何判断当前是同一层还是树枝呢?使用一个额外的 used 数组来标识。

详细的解释参考文档。

class Solution {
private:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(vector<int>& candidates, int target, int sum, int startIndex, vector<bool>& used) {
        if (sum == target) {
            result.push_back(path);
            return;
        }
        for (int i = startIndex; i < candidates.size() && sum + candidates[i] <= target; i++) {
            // used[i - 1] == true,说明同一树枝candidates[i - 1]使用过
            // used[i - 1] == false,说明同一树层candidates[i - 1]使用过
            // 要对同一树层使用过的元素进行跳过
            if (i > 0 && candidates[i] == candidates[i - 1] && used[i - 1] == false) {
                continue;
            }
            sum += candidates[i];
            path.push_back(candidates[i]);
            used[i] = true;
            backtracking(candidates, target, sum, i + 1, used); // 和39.组合总和的区别1,这里是i+1,每个数字在每个组合中只能使用一次
            used[i] = false;
            sum -= candidates[i];
            path.pop_back();
        }
    }

public:
    vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
        vector<bool> used(candidates.size(), false);
        path.clear();
        result.clear();
        // 首先把给candidates排序,让其相同的元素都挨在一起。
        sort(candidates.begin(), candidates.end());
        backtracking(candidates, target, 0, 0, used);
        return result;
    }
};


3 分割回文串

  • 🎈 文档讲解
  • 🎈 视频讲解
  • 🎈 做题状态:

3.1 切割

使用回溯进行切割是如何进行的呢? 如何切割是回溯的一种经典题目了。

犀利糊涂写出来了,有一个疑惑的地方,在判断当前子串不是回文串时,为什么是进入下一个循环而不是跳出所有循环。

因为同一个循环内是同一层,加入当前层的前面有一个节点不满足,直接break的话,后面满足的节点也会被去除。所以应该使用continue。continue是跳过当前的节点,也就是说以这个节点为根的所有结果肯定都是不满足的。

class Solution {
public:
    // 判断是否是回文串
    bool isPalindrome(string s)
    {
        for (int i = 0; i < s.size()/2; i++)
        {
            if (s[i] != s[s.size() - 1 - i])
            {
                return false;
            }
        }
        return true;
    }

    // 回溯 (startIndex从0开始)
    void backTracing(string& s, int startIndex, vector<string>& path, vector<vector<string>>& paths)
    {
        // 终止条件
        if (startIndex == s.size())
        {
            paths.emplace_back(path);
            return;
        }

        // 单层回溯逻辑
        for (int i = startIndex; i < s.size(); i++)
        {
            string tmp = s.substr(startIndex, i - startIndex + 1);
            if (isPalindrome(tmp))
            {
                path.emplace_back(tmp);
                backTracing(s, i + 1, path, paths);
                path.pop_back();
            }
            else
            {
                continue;	// 注意是continue ,而不是break
            }
        }
    }

    vector<vector<string>> partition(string s) 
    {
        vector<string> path;
        vector<vector<string>> paths;
        backTracing(s, 0, path, paths);
        return paths;
    }
};

3.2 总结:分割和组合的区别

分割和组合的区别:组合是每次选取一个元素出来然后加入到path数组中。而分割就是取一个区间的元素出来,然后加入到path数组中;

那么分割区间的数据如何获取呢?根据当期遍历的 i 和 startIndex 就可以进行确定。
string tmp = s.substr(startIndex, i - startIndex + 1); 这个就是把区间中的字符串获取出来。

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

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

相关文章

【Entity Framework】EF配置文件设置详解

【Entity Framework】EF配置文件设置详解 文章目录 【Entity Framework】EF配置文件设置详解一、概述二、实体框架配置部分三、连接字符串四、EF数据库提供程序五、EF侦听器六、将数据库操作记录到文件中七、Code First默认连接工厂八、数据库初始值设定项 一、概述 EF实体框架…

Taro打包生成不同目录

使用taro init创建taro项目时&#xff0c;taro默认打包目录是&#xff1a; /config/index.js outputRoot:dist默认的目录&#xff0c;编译不同平台代码时就会覆盖掉&#xff0c;为了达到多端同步调试的目的&#xff0c;这时需要修改默认生成目录了&#xff0c;通过查看官方文…

Redis 群集

目录 一、集群的三种模式 1.1 Redis 主从复制 主从复制的作用&#xff1a; 主从复制流程&#xff1a; 主从复制的过程/原理 搭建Redis 主从复制 1.2 Redis 哨兵模式 哨兵模式原理: 哨兵模式的作用&#xff1a; 哨兵模式的结构 故障转移机制&#xff1a; 搭建Redis …

[尚硅谷 flink] 基于时间的合流——双流联结(Join)

文章目录 8.1 窗口联结&#xff08;Window Join&#xff09;8.2 **间隔联结&#xff08;Interval Join&#xff09;** 8.1 窗口联结&#xff08;Window Join&#xff09; Flink为基于一段时间的双流合并专门提供了一个窗口联结算子&#xff0c;可以定义时间窗口&#xff0c;并…

虚拟主机WordPress网站安装教程

一般的企业官网&#xff0c;简站WordPress小编都推荐使用虚拟主机&#xff0c;用虚拟主机搭建一般的WordPress企业官网足够用了。最主要的好处是使用虚拟主机可以省去了主机维护的成本。 下面是以简站WordPress主题在虚拟主机搭建企业官网为例子&#xff0c;写的一个教程&…

无人机详细操作方法:

不同型号的无人机操作方法会有所区别&#xff0c;以云卓无人机为例&#xff0c;为你介绍其操作方法&#xff1a; 1. 打开机臂&#xff0c;安装护架、红外避障头&#xff0c;盖上后盖&#xff1b; 2. 打开飞机和遥控器&#xff0c;将两个油门的外八节进行校准&#xff1b; 3.…

Echarts-实现地图并轮播地图信息

目录 ./map-geojson/jinhua.json./CenterMap.vue./center.vue 使用地图组件效果 ./map-geojson/jinhua.json {"type":"FeatureCollection","features":[{"type":"Feature","properties":{"adcode":330…

ZLMediaKit ubantu 下编译

1、获取代码 #国内用户推荐从同步镜像网站gitee下载 git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit cd ZLMediaKit #千万不要忘记执行这句命令 git submodule update --init二、依赖库 Debian系(包括ubuntu&#xff09;系统下安装依赖的方法&#xff1a; #除了…

什么是 SD NAND?

什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。 什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。今天我们雷龙也精心准备了 SD NAND 的一个介绍。其实很多工程师朋友对 CS 创世 SD NAND 有很多称呼。比如&#xff1a;贴片式 T 卡…

Ethernet 汇总

Ethernet系统 硬件最小系统 CPU:可以是复杂的芯片,也可以是小的单片机DMA:用于减轻CPU负担,搬运数据系统Memory<->FIFOMAC:可以集成在芯片里面,用于CPU和PHY之间的通信MII:接口用于MAC和PHY的通信,包括控制MDIO和数据DataPHY:模拟器件,最底层,数据收发源头软件…

AI智慧医疗:探索机器学习在医疗保健中的应用与进展

&#x1f9d1; 作者简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向的学习指导…

TEMU平台重要合规内容!关于 RSL Report 铅镉/ RSL Phthalate邻苯

TEMU平台重要合规内容&#xff01;关于 RSL Report 铅镉 / RSL Phthalate 邻苯 的资质认证&#xff01; 欧盟对进口和在欧盟内销售的电子产品都有明确的安全、环保、健康等相关标准要求。 对于可能存在的产品有害物质&#xff0c;欧盟是明确禁止销售的。 因此拼多多跨境平台…

停用net stop mysql 服务名无效。

net stop mysql服务名 错误截图 解决方案 1. 按下 Win R 键&#xff0c;然后输入 services.msc 并按下 Enter 键&#xff0c;打开服务管理器 &#xff0c;查找与 MySQL 相关的服务 重新运行 net stop mysql服务名

python学习笔记——类

1. 类和对象**** 类、类属性、类方法不需要实例化就可以直接访问 实例相关&#xff0c;如实例属性、实例方法必须实例化后才可以访问 1.1. 类、类属性、实例属性、私有属性**** 1.1.1. 定义**** 类就是拥有相同属性和功能对象的集合 动物&#xff1a;猫、狗、鸡 人类&…

PCA算法(Principal Component Analysis)揭秘

经典PCA算法 PCA算法的应用包括降维、有损数据压缩、特征抽取、数据可视化等。目前PCA算法有两个通用定义&#xff0c;能殊途同归&#xff0c;得到相同的结果。一方面&#xff0c;我们可以用正交投影来定义PCA&#xff0c;即将数据投影到更低维的线性子空间&#xff0c;也被称…

【LAMMPS学习】八、基本知识的讨论(1.2)可视化 LAMMPS 快照

8. 基本知识的讨论 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语&#xff0c;以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和…

【单】Unity _RPG项目中的问题

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a; ⭐…

CVE-2023-2928 DedeCMS 文件包含漏洞getshell 漏洞分析

DedeCMS&#xff08;也称为织梦CMS&#xff09;是一款基于PHPMySQL的开源内容管理系统。 在 DedeCMS 5.7.106 及之前的版本中发现一个漏洞。它已被宣布为关键。受此漏洞影响的是未知功能的文件uploads/dede/article_allowurl_edit.php。对参数 allurls 的操作会导致代码注入。…

用three.js 制作鸡你太美游戏——只因大逃杀

看到网上有好多关于坤坤的游戏&#xff0c;自己突发奇想&#xff0c;用前端的three.js制作一款同人游戏&#xff0c;因是初学three.js&#xff0c;开发的游戏内容相对较少&#xff0c;但作为一个真正的man必须得玩一下 链接&#xff1a; 只因大逃杀https://www.jaron.top/app…

【ZBrush】制作章鱼练习 01——头部

目录 本篇效果 步骤 一、准备工作 二、制作头部外形 三、制作眼睛 本篇效果 步骤 一、准备工作 我们需要制作的模型如下 首先创建一个球体 点击编辑对象 点击“生成 多边形网格物体” 选择“MatCap Gray”材质&#xff0c;颜色设置为白色 要打开“Mrgb”通道和“绘制”选…