代码随想录训练营21day-回溯4

一、491 非递减子序列

本题不能按照前面的方法来判断重复数字,因为数组本来就带顺序属性,不能移动。

主要在于怎么选择子序列:首先同层的处理,需要判断,当前层前面出现过的数字,后面不能再使用(很重要!!);另外,如果path头部数字和当前数字不是递增的,那么需要跳过。

int* path;int** result; //int used[201];int path_index;int resize;int* recolsize;void backtracking(int* nums, int numsSize, int startidx)
{if(path_index > 1){result[resize] = (int*)malloc(sizeof(int) * path_index);memcpy(result[resize], path, path_index * sizeof(int));recolsize[resize] = path_index;resize++;}int used[201] = {0};for(int i = startidx; i < numsSize; i++){/**不满足条件的情况**/if((path_index > 0 && nums[i] < path[path_index -1]) || (used[nums[i] + 100] == 1))//path[path_index -1]是top元素{continue;}path[path_index++] = nums[i];used[nums[i] + 100] = 1;backtracking(nums, numsSize, i+ 1);path_index--;}
}int** findSubsequences(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {path = (int*)malloc(sizeof(int) * 20);result = (int**)malloc(sizeof(int*) * 50000);recolsize = (int*)malloc(sizeof(int) * 50000);path_index = 0;resize = 0;*returnSize = 0;*returnColumnSizes = NULL;if(numsSize <= 0){return NULL;}backtracking(nums, numsSize, 0);*returnSize = resize;*returnColumnSizes = recolsize;return result;
}

二、46 全排列

全排列是找所有可能的组合,因此,不需要用startindx来拆分了,数字都会重复使用,但是在纵向迭代时候,需要记录这个值是否使用过,如果使用过,那么跳出;

int** result;
int* path;
int path_idx;
int* used;
int resize;
int* recolsize;void backtracking(int* nums, int numsSize, int* used)
{if(path_idx == numsSize){result[resize] = (int*)malloc(sizeof(int) * path_idx);recolsize[resize] = path_idx;memcpy(result[resize], path, path_idx * sizeof(int));resize++;return;}for(int i = 0; i < numsSize; i++){if(used[i] == 1){continue;}path[path_idx++] = nums[i];used[i] = 1;backtracking(nums, numsSize, used);used[i] = 0;path_idx--;}}int** permute(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {result = (int*)malloc(sizeof(int*) * 50000);path = (int*)malloc(sizeof(int) * 10);int* used = (int*)calloc(10, sizeof(int));//malloc(sizeof(int) * 10);path_idx = 0;resize = 0;recolsize = (int*)malloc(sizeof(int) * 50000);*returnSize = 0;*returnColumnSizes = NULL;if(numsSize <= 0){return NULL;}backtracking(nums, numsSize, used);*returnColumnSizes = recolsize;*returnSize = resize;return result;}

三、全排列II

 主要是理解used在树枝和树层的含义!

void sortArr(int* arr, int size)
{for(int i = 0; i < size; i++){for(int j = i + 1; j < size; j++){if(arr[i] > arr[j]){int tmp = 0;tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}}}
}
int** result;
int* path;
int path_idx;
int* used;
int resize;
int* recolsize;// used[i - 1] == true,说明同一树枝nums[i - 1]使用过// used[i - 1] == false,说明同一树层nums[i - 1]使用过// 如果同一树层nums[i - 1]使用过则直接跳过
void backtracking(int* nums, int numsSize, int* used)
{if(path_idx == numsSize){result[resize] = (int*)malloc(sizeof(int) * path_idx);recolsize[resize] = path_idx;memcpy(result[resize], path, path_idx * sizeof(int));resize++;return;}for(int i = 0; i < numsSize; i++){if(i > 0 && (used[i -1] == 0) && (nums[i] == nums[i -1])){continue;}if(used[i] == 1){continue;}path[path_idx++] = nums[i];used[i] = 1;backtracking(nums, numsSize, used);used[i] = 0;path_idx--;}}int** permuteUnique(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {result = (int*)malloc(sizeof(int*) * 50000);path = (int*)malloc(sizeof(int) * 10);int* used = (int*)calloc(10, sizeof(int));//malloc(sizeof(int) * 10);path_idx = 0;resize = 0;recolsize = (int*)malloc(sizeof(int) * 50000);*returnSize = 0;*returnColumnSizes = NULL;if(numsSize <= 0){return NULL;}sortArr(nums, numsSize);backtracking(nums, numsSize, used);*returnColumnSizes = recolsize;*returnSize = resize;return result;
}

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

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

相关文章

2024年阿里云4核8G配置云服务器价格低性能高!

阿里云4核8G服务器租用优惠价格700元1年&#xff0c;配置为ECS通用算力型u1实例&#xff08;ecs.u1-c1m2.xlarge&#xff09;4核8G配置、1M到3M带宽可选、ESSD Entry系统盘20G到40G可选&#xff0c;CPU采用Intel(R) Xeon(R) Platinum处理器&#xff0c;阿里云优惠 aliyunfuwuqi…

代码随想录算法训练营第二十九天|491.递增子序列、46.全排列、46.全排列II

491. 非递减子序列 思路&#xff1a; 在90.子集II (opens new window)中我们是通过排序&#xff0c;再加一个标记数组来达到去重的目的。 而本题求自增子序列&#xff0c;是不能对原数组进行排序的&#xff0c;排完序的数组都是自增子序列了。 所以不能使用之前的去重逻辑&…

【模拟】Leetcode 数青蛙

题目讲解 1419. 数青蛙 算法讲解 class Solution { public:int minNumberOfFrogs(string croakOfFrogs) {string target "croak";int n target.size();//保存target每个字符的位置indexunordered_map<char, int>index;for(int i 0; i < n; i)index[tar…

必应Bing国内广告推广,帮助企业降低获客成本!

搜索引擎广告作为数字营销的重要手段之一&#xff0c;因其精准定位和效果可衡量而备受青睐。而在众多搜索引擎平台中&#xff0c;必应Bing以其独特的市场定位和用户群体成为不可忽视的广告推广渠道。云衔科技作为一家专业的数字营销服务提供商&#xff0c;致力于帮助企业实现高…

深入理解GCC/G++在CentOS上的应用

文章目录 深入理解GCC/G在CentOS上的应用编译C和C源文件C语言编译C语言编译 编译过程的详解预处理编译汇编链接 链接动态库和静态库静态库和动态库安装静态库 结论 深入理解GCC/G在CentOS上的应用 在前文的基础上&#xff0c;我们已经了解了CentOS的基本特性和如何在其上安装及…

Windows 部署ChatGLM3大语言模型

一、环境要求 硬件 内存&#xff1a;> 16GB 显存: > 13GB&#xff08;4080 16GB&#xff09; 硬盘&#xff1a;60G 软件 python 版本推荐3.10 - 3.11 transformers 库版本推荐为 4.36.2 torch 推荐使用 2.0 及以上的版本&#xff0c;以获得最佳的推理性能 二、部…

37-1 Python 的 requests 库发送 GET 请求

靶场环境准备:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客 一、requests库介绍: requests库是用 Python 语言编写的第三方库,用于访问网络资源。它基于 urllib,但相比 urllib 更加简单、方便和易于使用。通过 requests 库,可以实现…

你觉得职场能力重要还是情商重要?

职场能力和情商都是职业成功的关键因素&#xff0c;它们在不同的情境和角色中扮演着不同的作用。很难简单地说哪一个更重要&#xff0c;因为它们通常是相辅相成的。 职场能力包括专业技能、知识水平、解决问题的能力、工作效率、创新思维等。这些能力是完成工作任务、达成职业目…

【NUCLEO-G071RB】003——GPIO-按键控制LED灯

NUCLEO-G071RB&#xff1a;003——GPIO-按键控制LED灯 设计目标电路原理图芯片配置程序修改 设计目标 用输入控制输出&#xff0c;即以蓝色按键B1的输入控制LED4灯的输出 细节&#xff1a; 若判定为按键按下中&#xff0c;则LED灭灯&#xff0c;否则亮灯按键按下和抬起的检查…

【Spring进阶系列丨第十篇】基于注解的面向切面编程(AOP)详解

文章目录 一、基于注解的AOP1、配置Spring环境2、在beans.xml文件中定义AOP约束3、定义记录日志的类【切面】4、定义Bean5、在主配置文件中配置扫描的包6、在主配置文件中去开启AOP的注解支持7、测试8、优化改进9、总结 一、基于注解的AOP 1、配置Spring环境 <dependencie…

多ip证书实现多个ip地址https加密

在互联网快速发展的现在&#xff0c;很多用户会使用由正规数字证书颁发机构颁发的数字证书&#xff0c;其中IP数字证书就是只有公网IP地址网站的用户用来维护网站安全的手段。由于域名网站比较方便记忆&#xff0c;只有公网IP地址的网站是很少的&#xff0c;相应的IP数字证书产…

向量数据库与图数据库:理解它们的区别

作者&#xff1a;Elastic Platform Team 大数据管理不仅仅是尽可能存储更多的数据。它关乎能够识别有意义的见解、发现隐藏的模式&#xff0c;并做出明智的决策。这种对高级分析的追求一直是数据建模和存储解决方案创新的驱动力&#xff0c;远远超出了传统关系数据库。 这些创…

JavaScript与HTML交互

JavaScript与HTML交互 一、在页面中直接编写JS代码二、从外部引入JS代码一、在页面中直接编写JS代码 首先创建一个html页面,并在页面中编写一段JS代码,注意,JS代码要放在标签中,然后实现html代码和JavaScript的交互。 <!DOCTYPE html> <html lang="en"…

C 命令行参数

执行程序时&#xff0c;可以从命令行传值给 C 程序。这些值被称为命令行参数&#xff0c;它们对程序很重要&#xff0c;特别是当您想从外部控制程序&#xff0c;而不是在代码内对这些值进行硬编码时&#xff0c;就显得尤为重要了。 命令行参数是使用 main() 函数参数来处理的&…

单链表的应用

文章目录 目录1. 单链表经典算法OJ题目1.1 [移除链表元素](https://leetcode.cn/problems/remove-linked-list-elements/description/)1.2 [链表的中间节点](https://leetcode.cn/problems/middle-of-the-linked-list/description/)1.3 [反转链表](https://leetcode.cn/problem…

考研数学|《1800》《660》《880》如何选择和搭配?(附资料分享)

直接说结论&#xff1a;基础不好先做1800、强化之前660&#xff0c;强化可选880/1000题。 首先&#xff0c;传统习题册存在的一个问题是题量较大&#xff0c;但难度波动较大。《汤家凤1800》和《张宇1000》题量庞大&#xff0c;但有些题目难度不够平衡&#xff0c;有些过于简单…

使用 ECharts 绘制咖啡店各年订单的可视化分析

使用 ECharts 绘制咖啡店各年订单的可视化分析 在这篇博客中&#xff0c;我将分享一段使用 ECharts 库创建可视化图表的代码。通过这段代码&#xff0c;我们可以直观地分析咖啡店各年订单的情况。 饼图 这段代码包含了两个 ECharts 图表&#xff0c;一个是饼图&#xff0c;用…

Linux安装及应用管理

目录 一.Linux应用程序基础 应用程序与系统命令的关系​编辑 典型应用程序的目录结构 常见的软件包封装类型 二.rpm软件包操作管理 RPM Red-Hat Package Manager rmp命令的格式 rpm软件包操作管理 查询已安装的RPM软件信息 查询未安装的RPM软件包文件中信息 安装、升…

1.SCI各模块

1.学会“抄” 写论文&#xff0c;一定要学会“抄”&#xff01;这样才能事半功倍&#xff0c;尤其是对于初次写作的新手&#xff0c;否则写作过程一定会让你痛不欲生&#xff0c;而且写出来的东西就是一坨shi&#xff0c;不仅折磨自己&#xff0c;也折磨导师。 写论文与建大楼…

基于STC12C5A60S2系列1T 8051单片机的带字库液晶显示器LCD12864数据传输并行模式显示32行点x128列点字模串的应用

基于STC12C5A60S2系列1T 8051单片机的带字库液晶显示器LCD12864数据传输并行模式显示32行点x128列点字模串的应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍液晶显…