代码随想录训练营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.mfbz.cn/a/553037.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据库服务的运行与登录

打开数据库服务 数据库服务: SQL Server(MSSQLServer) 运行在服务器端的应用程序, 提供数据的存储 / 处理和事务等在使用DBMS的客户端之前必须首先打开该服务 客户端连接到服务器 关于客户端 / 服务器端的说明 客户端 : 数据库管理系统(DBMS), 应用程序服务器端 : 安装的数据…

深澜计费管理系统 /demo/proxy存在任意文件读取漏洞

声明&#xff1a; 本文仅用于技术交流&#xff0c;请勿用于非法用途 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任。 简介 深澜计费管理系统是一款用于网络设备计费管理的软件…

nginx部署上线

1. windows配置nginx 打包命令 npm run build:prod 1. 安装 nginx mac windows 2. mac / windows 环境下ngnix部署启动项目 2. nginx 解决 history 的 404 问题 3. nginx配置代理解决生产环境跨域问题

元宇宙-虚拟世界的安全风险如何应对

元宇宙&#xff08;Metaverse&#xff09;是一个虚拟时空间的集合&#xff0c;由一系列的增强现实&#xff08;AR&#xff09;、虚拟现实&#xff08;VR&#xff09;和互联网&#xff08;Internet&#xff09;所组成。这个虚拟时空间是一个持续存在的、由众多虚拟世界互相连接而…

链表OJ - 5(合并两个有序链表)

题目描述&#xff08;来源&#xff09; 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 思路 需创建一个头结点&#xff0c;然后从两个链表的表头开始依次比较传入的两个链表的结点的大小&#xff0c;并将两个链表中较小的…

Linux LVM 逻辑卷管理

Logical Volume Manager&#xff0c;逻辑卷管理 能够在保持现有数据不变的情况下动态调整磁盘容量&#xff0c;从而提高磁盘管理的灵活性/boot分区用于存放引导文件&#xff0c;不能基于LVM创建 三大概念&#xff1a; 物理卷PV基于硬盘或分区设备创建而来&#xff0c;生成N多…

自媒体博客Spimes主题 X7.1 简约新闻自媒体类的 typecho 主题源码

spimes主题专为博客、自媒体、资讯类的网站设计开发&#xff0c;自适应兼容手机、平板设备。一款简约新闻自媒体类的 typecho 主题&#xff0c;设计上简约、干净、精致、响应式&#xff0c;后台设置更是强大而且实用的新闻自媒体类主题。 PS&#xff1a;5.0版本改动比较多&…

Golang插件系统实现

插件可以在解耦的基础上灵活扩展应用功能&#xff0c;本文介绍了如何基于Golang标准库实现插件功能&#xff0c;帮助我们构建更灵活可扩展的应用。原文: Plugins with Go 什么是插件 简单来说&#xff0c;插件就是可以被其他软件加载的软件&#xff0c;通常用于扩展应用程序的功…

数据库的特点

前面讲了&#xff0c;数据库是有组织的&#xff0c;规范的把数据保存起来的。 怎么个组织的&#xff0c;规范的&#xff1f; 数据库的特点&#xff1a; 1.将数据放到数据表格&#xff08;二维表&#xff09;中&#xff0c;在将表格放到库中。 2.一个数据库中可以有多张表&am…

【.Net动态Web API】背景与实现原理

&#x1f680;前言 本文是《.Net Core进阶编程课程》教程专栏的导航站&#xff08;点击链接&#xff0c;跳转到专栏主页&#xff0c;欢迎订阅&#xff0c;持续更新…&#xff09; 专栏介绍&#xff1a;通过源码实例来讲解Asp.Net Core进阶知识点&#xff0c;让大家完全掌握每一…

分布式限流——Redis + Lua脚本实现令牌桶算法

主要思路概括如下&#xff1a; 定义数据结构&#xff1a; 使用Redis存储令牌桶的状态&#xff0c;包括当前令牌数&#xff08;KEYS[1]&#xff09;和上一次令牌填充的时间戳&#xff08;KEYS[1]:last&#xff09;。 计算新增令牌&#xff1a; 获取当前系统时间与上次令牌填充时…

中科亿海微-CL1656功能验证开发板

I. 引言 A. 研究背景与意义 CL1656是一款精度高、功耗低、成本低的5V单片低功耗运放&#xff0c;由核心互联公司研发制造&#xff0c;CL1656 是一个 16-bit、快速、低功耗逐次逼近型 ADC&#xff0c;吞吐速率高达 250 kSPS&#xff0c;并且内置低噪声、宽 带宽采样保持放大器。…

Vision Pro 零基础教程:1.机器视觉概述

文章目录 机器视觉简介机器视觉的发展历史机器视觉的结构组成机器视觉的应用工业相机分类1. 按传感器类型分类&#xff1a;2. 按分辨率分类&#xff1a;3. 按扫描方式分类&#xff1a;4. 按输出信号类型分类&#xff1a;5. 按应用领域分类&#xff1a;6. 按接口类型分类&#x…

React【Day2】

React表单控制 受控绑定 概念&#xff1a;使用React组件的状态&#xff08;useState&#xff09;控制表单的状态 双向绑定 MVVM 报错记录&#xff1a; 错误代码&#xff1a; import { useState } from "react";const App () > {const [value, setValue] useS…

使用pytorch构建GAN模型的评估

本文为此系列的第六篇对GAN的评估&#xff0c;上一篇为Controllable GAN。文中使用训练好的分类模型的部分网络提取特征将真实分布与生成分布进行对比来评估模型的好坏&#xff0c;若有不懂的无监督知识点可以看本系列第一篇。 原理 一般来说&#xff0c;我们评估模型的好坏可…

DataGridView添加行号隔行变色

运行效果 颜色对应关系 类实现代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;namespace WindowsFormsApp1 {…

二刷大数据(二)- Spark

目录 SparkHadoop区别核心组件运行架构Master&WorkerApplication (Driver)Executor RDD概念yarn下工作原理算子依赖血缘关系阶段划分广播变量 shuffle流程SparkSQLDataSet、DataFrame、RDD相互转换 SparkStreaming Spark Spark是一种基于内存的快速、通用、可扩展的大数据…

C# Solidworks二次开发:比较两个solidworks文档属性相关API详解

大家好&#xff0c;今天要讲的文章是关于如何比较两个solidworks文档。 下面是API的介绍&#xff1a; &#xff08;1&#xff09;第一个为Close&#xff0c;这个API的含义为在比较solidworks文档以后执行必要的清理。下面是官方的具体解释&#xff1a; 其没有输入参数&#x…

MySQL Workbench下载安装、 MySQL Workbench使用

官方下载链接;MySQL :: Download MySQL Workbench 下载好懒人安装&#xff0c;也可自己选择目录 下面是使用&#xff1a; 连接数据库&#xff1a; 填写数据库连接信息&#xff1a; 基本操作部分&#xff1a; 数据导入导出&#xff1a; 导出/备份 导入&#xff1a; 生产er图…

【机器学习】科学库使用第5篇:Matplotlib,学习目标【附代码文档】

机器学习&#xff08;科学计算库&#xff09;完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;机器学习&#xff08;常用科学计算库的使用&#xff09;基础定位、目标&#xff0c;机器学习概述定位,目标,学习目标,学习目标,1 人工智能应用场景,2 人工智能小…
最新文章