代码随想录第27天 | 39. 组合总和、40.组合总和II、131.分割回文串

一、前言

今天的主题还是回溯算法,还是根据那个backtracking模板,但是今天会涉及到去重和一些小细节的问题。

二、组合总和

1、思路:

我一开始的想法就是在for循环转化为:

for(int i = 0; i < size; i++)

但是这个是会陷入一个死循环,一直会在0的这个位置进行累加,所以必须使用start作为一个 

一个i的初始变量,这样才能实现不同数字且相同的累加。

再有一个关键的因素终止条件:

if (sum > target){return;
}

这个如果没有,那就一直循环递归去了。

2、整体代码如下:

class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int> &candidates, int target, int sum, int start) {if (sum > target) {return;}if (sum == target) {result.push_back(path);return;}for (int i = start; i < candidates.size(); i++) {sum += candidates[i];path.push_back(candidates[i]);backtracking(candidates, target, sum ,i);sum -= candidates[i];path.pop_back();}}
public:vector<vector<int>> combinationSum(vector<int>& candidates, int target) {result.clear();path.clear();backtracking(candidates, target, 0, 0);return result;}
};

剪枝操作,for循环的修正:

for (int i = start; i < candidates.size() && sum + candidates[i] <= target; i++)

 整体代码:

class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int> &candidates, int target, int sum, int start) {if (sum > target) {return;}if (sum == target) {result.push_back(path);return;}for (int i = start; i < candidates.size() && sum + candidates[i] <= target; i++) {sum += candidates[i];path.push_back(candidates[i]);backtracking(candidates, target, sum ,i);sum -= candidates[i];path.pop_back();}}
public:vector<vector<int>> combinationSum(vector<int>& candidates, int target) {result.clear();path.clear();sort(candidates.begin(), candidates.end()); // 需要排序backtracking(candidates, target, 0, 0);return result;}
};

 

三、组合总和|||

1、思路:

我的最开始的思路并没有包括到去重的思想

导致出现了多个重复的答案,

思路图是这样的:

首先就得有一个used数组,全部设置为false然后在递归回溯过程中,涉及到了两个新的名词:树尾和树层。树层是递归的每一层,树尾就是树的深度,在这个题目当中,我们所需要去重的是数层,当前一个和后一个相同时,used为false说明没有被使用,就可以去掉这个重复的元素了,而在深度遍历中,就没有这种情况,后面为ture就说明在深度当中,就可以往下遍历了。

这里也有一个小小的剪枝操作:

(sum + candidates[i]) <= target

 2、整体代码如下:

class Solution {
private:vector<int> path;vector<vector<int>> result;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++) {// 去重if (i > 0 && candidates[i] == candidates[i - 1] && used[i - 1] == false) {continue;}path.push_back(candidates[i]);sum += candidates[i];used[i] = true;backtracking(candidates, target, sum, i + 1, used);// 回溯used[i] = false;path.pop_back();sum -= candidates[i];}}
public:vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {// 创建一个判定数组vector<bool> used(candidates.size(), false);// 需要先排序sort(candidates.begin(), candidates.end());backtracking(candidates, target, 0, 0, used);return result;}
};

 四、分割回文串

1、思路:

这个题目还是比较抽象的,首先来看一下这个分割的图例:

这是不断往下递归,分割,回溯,递归,分割的过程。直到size == startIndex才是停止,所以终止条件就是:

if (s.size() == startIndex)

就说明可以终止了,内部执行的语句就是:

{result.push_back();return;
}

 这里的小小的疑惑就是为什么一到最后就可以直接添加了,而不需要判断是否为回文串。

这里的判断逻辑主要是在for循环中去体现的。

(1)返回值和参数为:

void backtracking(tring &s, int startIndex)

这里的startIndex就是作为切割线来使用的;

(2)终止条件刚刚说了到了,这里就不提了,然后就是进入for循环了,这里就需要加上一个判断是否为回文串的判断条件,如果是,那么就把子串添加到path中 ,这里是判断回文串函数:

    // 判断回文串函数bool isPalindrome(const string &s, int satrt, int end) {for (int i = satrt, j = end; i < j; i++, j--) {if (s[i] != s[j]) {return false;}}return true;}

 (3)for循环里面的组成如下

 

        // 大循环for (int i = startIndex; i < s.size(); i++) {// 判断是否为回文串if (isPalindrome(s, startIndex, i)) {path.push_back(s.substr(startIndex, i - startIndex + 1));} else {// 不是就继续在该树继续往下分割。continue;}// 递归backtracking(s, i + 1);// 回溯path.pop_back();}

 现在一行分割下去,到了低,就return,然后就是从序号1开始搜索,依次进行。

1、整体代码如下:

class Solution {
private:vector<string> path;vector<vector<string>> result;// startIndex就是切割线void backtracking(string s, int startIndex) {// 终止条件if (startIndex == s.size()) {result.push_back(path);return;}// 大循环for (int i = startIndex; i < s.size(); i++) {// 判断是否为回文串if (isPalindrome(s, startIndex, i)) {path.push_back(s.substr(startIndex, i - startIndex + 1));} else {// 不是就继续在该树继续往下分割。continue;}// 递归backtracking(s, i + 1);// 回溯path.pop_back();}}// 判断回文串函数bool isPalindrome(const string &s, int start, int end) {for (int i = start, j = end; i < j; i++, j--) {if (s[i] != s[j]) {return false;}}return true;}
public:vector<vector<string>> partition(string s) {backtracking(s, 0);return result;}
};

今日学习时间:2小时;

leave message:

The lights and shades, whose well-accorded strife gives all the strength and color of our life.

在我们的生活中,一切的力量和色彩,都来自苦乐的光影,以及适度的斗争。 

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

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

相关文章

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果 一、简单介绍 二、简单颜色反转效果实现原理 三、简单颜色反转效果案例实现简单步骤 四、注…

壁纸小程序Vu3(预览页面:弹窗)

1.展示跳转后的分类列表图片 classlist.vue <template><view class"classlist"><view class"content"><navigator class"item" v-for"item in 10"><image src"../../common/images/64.png" mode…

基于arkTS开发鸿蒙app应用案例——通讯录案例

1.项目所用技术栈 arkTS node.js express mongoDB 2.效果图 3.源码 Index.ets&#xff08;登录页&#xff09; 登陆时让前端访问数据库中已经存好的账号密码&#xff0c;如果可以查询到数据库中的数据&#xff0c;则账号密码正确&#xff0c;登录成功&#xff0c;否则登录…

Docker容器赋能TitanIDE:引领编程新纪元的集成开发环境

Docker是一种容器化技术&#xff0c;它可以将应用程序和其所有的依赖项打包到一个轻量级、可移植的容器中。以下是Docker的基本概念和优势&#xff1a; 基本概念&#xff1a; 镜像&#xff08;Image&#xff09;&#xff1a;一个镜像是一个只读的模板&#xff0c;可以用于创建…

17.应用负载压力测试

早些点&#xff0c;下午题考&#xff0c;最近几年出现的少&#xff1b; 备考较为简单&#xff1b;历年真题相似度高&#xff1b; 主要议题&#xff1a; 1.负载压力测试概述 注意这些测试细微的差别&#xff1b; 负载测试和压力测试的方法比较相似&#xff0c;但是目的不同&a…

学习 MongoDB:打开强大的数据库技术大门

一、基本概念 MongoDB 是一个基于分布式文件存储的文档数据库&#xff0c;由 C 语言编写。它旨在为 Web 应用提供可扩展的高性能数据存储解决方案。 相信MySQL我们非常的熟悉&#xff0c;那么MySQL的表结构与MongoDB的文档结构进行类比的话可能更好理解MongoDB。 MySQL的数据…

ubuntu 20 虚拟机配置静态ip

在/etc/netplan/ 中得文件里&#xff08;类似&#xff1a;01-network-manager-all.yaml&#xff09;添加 # Let NetworkManager manage all devices on this system network:ethernets:ens33:dhcp4: noaddresses: [192.168.40.128/24]gateway4: 192.168.40.2optional: truenam…

【iOS ARKit】3D 视频

在AR 中播放视频也是一种常见的需求&#xff0c;如在一个展厅中放置的虚拟电视上播放宣传视频&#xff0c;或者在游戏中为营造氛围而设置的虚拟电视视频播放&#xff0c;或者在识别的2D个人名片上播放自我介绍视频&#xff0c;因视频具有静态图像无法比拟的综合信息展示能力&am…

华为数通方向HCIP-DataCom H12-821题库(多选题:241-260)

第241题 [RTAospf100 [RTA-ospf-100]silent-intefaceGigabitEthernet 1/0/0上面是路由器RTA的部分配置,对于此部分的配置描述,正确的是: A、接口gigabitethemet 1/0/0的直连路由仍然可以发布出去 B、无法与该接口的直连邻居形成邻居关系 C、禁止接口gigabi tethemet 1/0/0发…

vscode 自用的一些配置

目录 1&#xff0c;修改默认配置1&#xff0c;关闭预览模式2&#xff0c;取消自动定位到左侧边栏 2&#xff0c;自定义快捷键1&#xff0c;手动定位到左侧边栏2&#xff0c;关闭其他3&#xff0c;其他常用快捷键 3&#xff0c;插件1&#xff0c;和 git 相关的GitlensGit Histor…

C++ 2024-4-1 作业

#include <iostream> using namespace std;class A { public:int a;A(int a):a(a){cout<<"A的有参构造"<<endl;} }; class B:virtual public A { public:int b;B(int a,int b):A(a),b(b){cout<<"B的有参构造"<<endl;} }; cl…

用Wireshark解码H.264

H264&#xff0c;你不知道的小技巧-腾讯云开发者社区-腾讯云 这篇文章写的非常好 这里仅做几点补充 init.lua内容&#xff1a; -- Set enable_lua to false to disable Lua support. enable_lua trueif not enable_lua thenreturn end-- If false and Wireshark was start…

华为云RDS for Mysql入门与配置

华为云RDS for MySQL支持混合SSD实例&#xff0c;它结合了华为云容器、本地SSD盘和高速云盘。 优势&#xff1a; 主备实例提供故障自动切换和手动切换&#xff0c;业务中断时间为秒级&#xff0c;以及异地灾难备份&#xff0c;最大程度上在出现故障的情况下保障整个数据库集群…

适用于智能断路器、新能源汽车充电枪锁、电动玩具、电磁门锁等的直流电机驱动芯片D6289ADA介绍

应用领域 适用于智能断路器&#xff08;家用或工业智能空开&#xff09;、新能源汽车充电枪锁、电动玩具、电磁门锁、自动阀门等的直流电机驱动。 功能介绍 D6289ADA是一款直流马达驱动芯片&#xff0c;它有两个逻辑输入端子用来控制电机前进、后退及制动。该电路具有良好的抗干…

天池医疗AI大赛[第一季] Rank8解决方案[附TensorFlow/PyTorch/Caffe实现方案]

团队成员&#xff1a;北京邮电大学 模式识别实验室硕士研究生 今年5月&#xff0c;参加了天池医疗AI大赛&#xff0c;这次比赛是第一次参加此类的比赛&#xff0c;经过接近半年的比赛&#xff0c;终于10月落下帷幕&#xff0c;作为第一次参加比赛&#xff0c;能在接近3000支队…

标定系列——预备知识-OpenCV中矫正相关函数(十二)

标定系列——预备知识-OpenCV中矫正相关函数&#xff08;十二&#xff09; 说明记录 说明 记录了OpenCV中的矫正相关函数的使用 记录

Can‘t connect to server on ‘localhost‘ (10061)

问题&#xff1a;电脑关机重启后&#xff0c;连接不上mysql了&#xff0c;报错信息如下&#xff1a;2002 - Cant connect to server on localhost (10061)解决办法&#xff1a;很大的原因是mysql服务没有启动&#xff0c;需要你重启一下mysql&#xff1a; 以管理员的身份运行cm…

从PDF到高清图片:一步步学习如何转换PDF文件为高清图片

引言 PDF文件是一种便携式文档格式&#xff08;Portable Document Format&#xff09;&#xff0c;最初由Adobe Systems开发&#xff0c;用于在不同操作系统和软件之间保持文档格式的一致性。PDF文件通常包含文本、图片、图形等多种元素&#xff0c;并且可以以高度压缩的方式存…

VScode 集成终端设置默认打开当前文件夹 mac系统

一.快捷键设置 搜索 openInIntegratedTerminal 如图&#xff1a; 二.设置cmd 默认打开位置 点击设置 搜索 ntegrated:cwd 如下图&#xff1a; 三.查看ip 快捷指令&#xff1a; ipconfig getifaddr en0

SpringBoot中Bean注册

Bean注解 Springboot中默认扫描启动类所在的包及其子包。 比如这里的DemoApplication是启动类&#xff0c;那么spring boot默认扫描com.example.demo这个包。 Controller、Service、Repository这三个注解是Component的衍生注解&#xff0c;它们经常会被添加到Controller层、Se…