【算法训练记录——Day28】

Day28——回溯算法Ⅳ

  • 1.复原IP地址
  • 2.[全排列](https://leetcode.cn/problems/permutations/submissions/539240290/)
  • 3.[全排列Ⅱ](https://leetcode.cn/problems/permutations-ii/description/)

● 93.复原IP地址
● 78.子集
● 90.子集II

1.复原IP地址

在这里插入图片描述
思路:相当于还是求所有子集,只是在这个基础上加了层判断

	vector<string> res;
	
	bool isValid(const string& s, int start, int end) {
		if(start > end) return false;	// 越界无效
		if(start != end && s[start] == '0') return false; // 初0以外首字符为0无效
		int num = 0;
		for(int i = start; i <= end; i++) {
			if(s[i] > '9' || s[i] < '0') return false;
			num = num * 10 + s[i] - '0';
			if(num > 255) return false;
		}
		return true;
	}
	
	void backtracking(string& s, int startIndex, int pointNum) {
		if(pointNum == 3) {
			if(isValid(s, startIndex, s.size() - 1)) {
				res.push_back(s);
			}
			return;
		}
		for(int i = startIndex; i < s.size(); i++) {
			if(isValid(s, startIndex, i)) {
				s.insert(s.begin() + i + 1, '.');		// 有效ip后面加上.
				backtracking(s, i + 2, pointNum + 1);	// 回溯 左闭右闭
				s.erase(s.begin() + i + 1);				// 回溯,删掉加上的.
			} else return;								// 无效ip直接剪枝
		}
		return;
	}

    vector<string> restoreIpAddresses(string s) {
    	res.clear();
		if(s.size() < 4 || s.size() > 12) return res; // 剪枝
		backtracking(s, 0, 0);
		return res;
	}

2.全排列

在这里插入图片描述
思路:刚开始认为把startIndex换成0不就是遍历全部了,但是写了一下发现,换成0 递归的逻辑应该是什么呢,从下一个开始,然后每次遍历全部元素,那不就有很多重复的?怎么过滤呢?卡住了,不会了。
用used数组标记当前已使用元素。

	vector<int> num;
	vector<bool> used;
	vector<vector<int>> res;
	
	void backtracking(const vector<int>& nums) {
		if(num.size() >= nums.size()) {
			res.push_back(num);
			return;
		}
		
		for(int i = 0; i < nums.size(); i++) {
			if(used[i] == true) continue;
			used[i] = true;
			num.push_back(nums[i]);
			backtracking(nums);
			num.pop_back();
			used[i] = false;
		}
		
		return;
	}

    vector<vector<int>> permute(vector<int>& nums) {
		used.resize(nums.size());
		backtracking();
		return res;
	}

3.全排列Ⅱ

在这里插入图片描述
思路:可包含重复元素。好熟悉,但是想不起来了。。应该是要排序,然后跳过一些重复元素。

void backtracking(const vector<int>& nums) {
        if(num.size() >= nums.size()) {
            res.push_back(num);
            return;
        }

        for(int i = 0; i < nums.size(); i++) {
        	// 此处有疑问
            if(i > 0 && nums[i] == nums[i-1] && used[i-1] == false) continue;
            if(used[i] == true) continue;
            used[i] = true;
            num.push_back(nums[i]);
            backtracking(nums);
            used[i] = false;
            num.pop_back();
        }
        return;
    }

    vector<vector<int>> permuteUnique(vector<int>& nums) {
        sort(nums.begin(), nums.end());
        used.resize(nums.size(), false);
        backtracking(nums);
        return res;
    }

在写这段代码时,考虑到需要对重复字符的控制 写成了这种

 if(i > 0 && nums[i] == nums[i-1]) continue;

按照我的想法,当 i>0 时,表示当前已经进行了一次回溯,开始遍历下一个元素,此时如果当前元素和前一元素相同,那么本次以当前元素为根的回溯就是不必要的,因为已经有相同元素进行了一次回溯。,这两次的结果应该是相同的。但是突然想到每次回溯时,这个代码也会运行,所以需要再加限制,保证在开始回溯时就剪枝。代码中在每次回溯前都把used[i] = true,因此当 used[i] == false时,即表示本次不是处于递归之中。但写代码的时候把 == false 写成了 == true,结果也能运行,但是没明白为什么。

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

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

相关文章

破布叶(Microcos paniculata)单倍型染色体级别基因组-文献精读22

Haplotype-resolved chromosomal-level genome assembly of Buzhaye (Microcos paniculata) 破布叶、布渣叶&#xff08;Microcos paniculata&#xff09;单倍型解析染色体级别基因组组装 摘要 布渣叶&#xff08;Microcos paniculata&#xff09;是一种传统上用作民间药物和…

因数与倍数 初级题目

最近又来更题了。这一次是《第三单元 因数与倍数第一部分》的初级题目。 参考答案见文尾 参考答案&#xff1a; CBDAABCBBACCCCCBCDCC

swift5 在当前控制器先dismiss后pop

如下图需要在present当前控制器时用全局变量firmwareUpgradePresentingVC先引用上一个控制器&#xff08;下面的代码亲测有效&#xff09; func dismissAndPop() {self.dismiss(animated: false) {firmwareUpgradePresentingVC.navigationController!.popViewController(animat…

VMware安装ubuntu22.4虚拟机超详细图文教程

一 、下载镜像 下载地址&#xff1a;Index of /ubuntu-releases/22.04.4/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 二、创建虚拟机 打开VMware点击左上角文件&#xff0c;创建新的虚拟机&#xff0c;打开后如下图&#xff1a; 下一步&#xff0c;镜像文件就是…

【perfetto分析性能学习笔记】

1.perfetto网站 https://ui.perfetto.dev/ 2.快捷键 3.线程状态分析 Runnable 表示线程正在运行或者等待CPU执行 Runnable (Preempted) 表示线程正在运行&#xff0c;但在运行过程中被其他高优先级线程抢占 Running 表示线程正在运行 Uninterruptible Sleep Uninterru…

6月13日 Qtday1

#include "mywidget.h" //腾讯会议的登录界面 MyWidget::MyWidget(QWidget *parent): QMainWindow(parent) {this->setFixedSize(468,830);//主窗口大小this->setStyleSheet("background-color:rgb(255,255,255)");//主窗口背景this->setWindowTi…

SAP MMRV/MMPV 物料账期月结月底月初开关

公告&#xff1a;周一至周五每日一更&#xff0c;周六日存稿&#xff0c;请您点“关注”和“在看”&#xff0c;后续推送的时候不至于看不到每日更新内容&#xff0c;感谢。 这是一条刮刮乐&#xff0c;按住全部选中&#xff1a;点关注的人最帅最美&#xff0c;欢迎&#xff1…

如何开发一个直播APP:功能介绍与开发步骤详解

随着移动互联网的迅猛发展&#xff0c;直播APP已经成为人们生活中不可或缺的一部分。无论是娱乐、教育、商业还是其他领域&#xff0c;直播APP都以其独特的实时互动性和广泛的受众群体而备受欢迎。那么&#xff0c;如何开发一个直播APP呢&#xff1f;本文将详细介绍直播APP的功…

【安装笔记-20240613-Linux-在 OpenWrt 的 LuCI界面支持命令行调试】

安装笔记-系列文章目录 安装笔记-20240613-Linux-在 OpenWrt 的 LuCI界面支持命令行调试 文章目录 安装笔记-系列文章目录安装笔记-20240613-Linux-在 OpenWrt 的 LuCI界面支持命令行调试 前言一、软件介绍名称&#xff1a;ttyd主页官方介绍特点 二、安装步骤测试版本&#xf…

ArrayList浅析

目录 一、ArrayList源码1.1 迭代器1.1.1 Itr源码浅析1.1.2 ListItr源码浅析 1.2 常用方法1.3 System.arraycopy1.4 ArrayList 的创建方式 二、引申问题2.1 ArrayList的大小是如何增加的&#xff1f;2.2 什么情况下你会使用ArrayList2.3 在索引中ArrayList的增加或者删除某个对象…

stable-diffusion 3 体验部署流程(ComfyUI)

环境准备 下载及简介 git clone https://huggingface.co/stabilityai/stable-diffusion-3-medium SD3 checkpoints&#xff1a; sd3_medium_incl_clips.safetensors (5.5GB)sd3_medium_incl_clips_t5xxlfp8.safetensors (10.1GB)sd3_medium.safetensors (4.3GB) 前两个可以…

flutter 导出iOS问题3

更新flutter版本后 macminihaomacMiniaodeMini SocialIM % flutter --version Flutter 3.7.12 • channel stable • https://github.com/flutter/flutter.git Framework • revision 4d9e56e694 (1 year, 2 months ago) • 2023-04-17 21:47:46 -0400 Engine • revision 1a6…

多款可观测产品全面升级丨阿里云云原生 5 月产品月报

云原生月度动态 云原生是企业数字创新的最短路径。 《阿里云云原生每月动态》&#xff0c;从趋势热点、产品新功能、服务客户、开源与开发者动态等方面&#xff0c;为企业提供数字化的路径与指南。 趋势热点 &#x1f947; 阿里云云原生产品负责人李国强&#xff1a;推进可…

磁盘管理 以及磁盘的分区 详细版

磁盘管理 track:磁道&#xff0c;就是磁盘上同心圆&#xff0c;从外向里&#xff0c;依次1号、2号磁道sector&#xff1a;扇区&#xff0c;将磁盘分成一个一个扇形区域&#xff0c;每个扇区大小是512字节&#xff0c;从外向里&#xff0c;依次是1号扇区、2号扇区cylinder&…

阀性能试验台测控系统响应时间的计算

阀性能试验台的测控系统响应时间是衡量系统响应速度和实时性能的重要指标。响应时间的计算涉及到信号采集、处理和执行的全过程。本文提供了一种详细的方法来计算和评估测控系统的响应时间。

分享一份 .NET Core 简单的自带日志系统配置,平时做一些测试或个人代码研究,用它就可以了

前言 实际上&#xff0c;.NET Core 内部也内置了一套日志系统&#xff0c;它是一个轻量级的日志框架&#xff0c;用于记录应用程序的日志信息。 它提供了 ILogger 接口和 ILoggerProvider 接口&#xff0c;以及一组内置的日志提供程序&#xff08;如 Console、Debug、EventSo…

每日5题Day23 - LeetCode 111 - 115

每一步向前都是向自己的梦想更近一步&#xff0c;坚持不懈&#xff0c;勇往直前&#xff01; 第一题&#xff1a;111. 二叉树的最小深度 - 力扣&#xff08;LeetCode&#xff09; /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeN…

Java基础面试重点-3

41. 简述线程生命周期(状态) 其它参考《多线程重点》中的说法。三种阻塞&#xff1a; 等待阻塞&#xff1a; 运行的线程执行o.wait()方法&#xff08;该线程已经持有锁&#xff09;&#xff0c;JVM会把该线程放入等待队列中。同步阻塞&#xff1a; 运行的线程在获取对象的同步…

u-boot(三) - 编译

一&#xff0c;u-boot编译过程总结 编译时的Makefile log&#xff1a; //链接得到ELF格式的u-boot arm-buildroot-linux-gnueabihf-ld.bfd -pie --gc-sections -Bstatic -Ttext 0x87800000 -o u-boot -T u-boot.lds arch/arm/cpu/armv7/start.o --start-group arch/arm/c…

【杂谈】-不同种类放大器及其区别

不同种类放大器及其区别 文章目录 不同种类放大器及其区别1、概述2、放大器种类2.1 如何衡量保真度2.2 如何测量放大器的效率 3、放大器分类3.1 A类放大器3.2 B 类放大器3.3 AB类放大器3.4 C类放大器3.5 其他放大器类别 1、概述 放大器是电子产品中最常用的电路之一。有几种类…