Follow Carl To Grow|【LeetCode】93.复原IP地址,78.子集,90.子集II

【LeetCode】93.复原IP地址

题意:有效 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,且不能含有前导 0),整数之间用 ‘.’ 分隔。
例如:“0.1.2.201” 和 “192.168.1.1” 是 有效 IP 地址,但是 “0.011.255.245”、“192.168.1.312” 和 “192.168@1.1” 是 无效 IP 地址。
给定一个只包含数字的字符串 s ,用以表示一个 IP 地址,返回所有可能的有效 IP 地址,这些地址可以通过在 s 中插入 ‘.’ 来形成。你 不能 重新排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。

思路:用回溯的思路,依次判断在哪里插入点号,有3个点即出口。检查切分出的区间内,是0xx、xxxx、大于255小于0、有非数字符号直接退出。

代码:

class Solution {
public:vector<string> m_res;// s[left, right]bool isValid(string s, int left, int right){if (left > right || right - left > 3){return false;}if ('0' == s[left] && left != right){return false;}int num = 0;for (int i = left; i <= right; ++i){if (!isdigit(s[i])){return false;}num = num * 10 + s[i] - '0';if (0 > num || 255 < num){return false;}}return true;}void backtracking(string s, int idx, int point){if (3 == point){if (isValid(s, idx, s.size() - 1)){m_res.push_back(s);}return;}for (int i = idx; i < s.size(); ++i){if (isValid(s, idx, i)){s.insert(s.begin() + i + 1, '.');++point;backtracking(s, i + 2, point);--point;s.erase(s.begin() + i + 1);}}}vector<string> restoreIpAddresses(string s) {backtracking(s, 0, 0);return m_res;}
};

【LeetCode】 78.子集

题意:给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。

解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。

思路:构建出多叉树,回溯收集每一个结点的值。

代码:

class Solution {
public:vector<int> m_path;vector<vector<int> > m_res;void backtracking(vector<int>& nums, int idx){// 收集子集m_res.push_back(m_path);for (int i = idx; i < nums.size(); ++i){m_path.push_back(nums[i]);backtracking(nums, i + 1);m_path.pop_back();}}vector<vector<int>> subsets(vector<int>& nums) {backtracking(nums, 0);return m_res;}
};

【LeetCode】90.子集II

题意:给你一个整数数组 nums ,其中可能包含重复元素,请你返回该数组所有可能的 子集(幂集)。
解集 不能 包含重复的子集。返回的解集中,子集可以按 任意顺序 排列。

思路:先对数组排序,然后回溯时利用used数组。如果当前值和前一个相同并且前一个没被选过,说明是回溯的结果,同一树层跑过,应该跳过。

代码:

class Solution {
public:vector<int> m_path;vector<vector<int>> m_res;void backtracking(vector<int>& nums, int idx, vector<bool> &used){m_res.push_back(m_path);for (int i = idx; i < nums.size(); ++i){if (0 < i && nums[i - 1] == nums[i] && !used[i - 1]){continue;}else{m_path.push_back(nums[i]);used[i] = true;backtracking(nums, i + 1, used);used[i] = false;m_path.pop_back();}}}vector<vector<int>> subsetsWithDup(vector<int>& nums) {// 去重需要排序,让相同的先待在一起sort(nums.begin(), nums.end());vector<bool> used(nums.size(), false);backtracking(nums, 0, used);return m_res;}
};

心态:“第七章 回溯算法part03” 拿下!
参考资料

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

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

相关文章

【深度学习】实现基于MNIST数据集的TensorFlow/Keras深度学习案例

基于TensorFlow/Keras的深度学习案例 实现基于MNIST数据集的TensorFlow/Keras深度学习案例0. 什么是深度学习&#xff1f;1. TensorFlow简介2. Keras简介3. 安装TensorFlow前的注意事项4. 安装Anaconda3及搭建TensorFlow环境1&#xff09; 下载安装Anaconda Navigator2&#xf…

go语言day06 数组 切片

数组 : 定长且元素类型一致,在索引逻辑上连续存储,数组的内存地址是存储的第一个元素的内存地址 几种创建方式: 仅声明 var nums [ 3 ] int 声明并赋值 var nums [ 2 ] string {"武沛齐","alex"} 声明并按下标赋值 var nums [ 3 ] int {0:88,2:1 } 省略…

ffmpeg+nginx+video实现rtsp流转hls流,web页面播放

项目场景&#xff1a; 最近调试海康摄像头需要将rtsp流在html页面播放,因为不想去折腾推拉流&#xff0c;所以我选择ffmpeg转hls流&#xff0c;nginx转发&#xff0c;html直接访问就好了 1.首先要下载nginx和ffmpeg 附上下载地址&#xff1a; nginx nginx news ffmpeg htt…

HttpServletRequest・getContentLeng・getContentType区别

getContentLength()&#xff1a; 获取客户端发送到服务器的HTTP请求主体内容的字节数&#xff08;长度&#xff09; 如果请求没有正文内容&#xff08;如GET&#xff09;&#xff0c;或者请求头中没有包含Content-Length字段&#xff0c;则该方法返回 -1 getContentType()&am…

eclipse中svn从分支合并到主干及冲突解决

1、将分支先commit&#xff0c;然后再update&#xff0c;然后再clean一下&#xff0c;将项目多余的target都清理掉。 2、将branches切换到trunk 3、工程上右键-》Team-》合并&#xff08;或Merge&#xff09; 4、默认选项&#xff0c;点击Next 5、有未提交的改动&#xff0c;…

文献阅读:通过双线性建模来破译神经元类型连接的遗传密码

文献介绍 文献题目 Deciphering the genetic code of neuronal type connectivity through bilinear modeling 研究团队 Mu Qiao&#xff08;美国加州理工学院&#xff09; 发表时间 2024-06-10 发表期刊 eLife 影响因子 7.7 DOI 10.7554/eLife.91532.3 摘要 了解不同神经元…

打造爆款秘籍:阿里巴巴国际站测评补单优势全攻略

在阿里巴巴国际站&#xff0c;买家复购率和其他销售指标是衡量产品市场潜力和销售成功与否的关键指标。当系统评估出产品具有巨大的市场潜力时&#xff0c;它会相应地增加对产品的流量支持&#xff1b;反之&#xff0c;如果潜力不足&#xff0c;产品的排名将会受到影响&#xf…

Node官网下载各个版本

node官网下载各个版本地址 例如 14.16.0 Index of /download/release/v14.16.0/

使用 Spring Boot 3.x 与图形学技术,添加电子印章防伪特征

使用 Spring Boot 3.x 与图形学技术,添加电子印章防伪特征 在电子办公和无纸化办公日益普及的今天,电子印章的使用越来越广泛。然而,如何确保电子印章的安全性和防伪能力成为了一个亟待解决的问题。本文将通过 Spring Boot 3.x 和图形学技术,深入探讨如何为电子印章添加防…

Redis-实战篇-什么是缓存-添加redis缓存

文章目录 1、什么是缓存2、添加商户缓存3、前端接口4、ShopController.java5、ShopServiceImpl.java6、RedisConstants.java7、查看Redis Desktop Manager 1、什么是缓存 缓存就是数据交换的缓冲区&#xff08;称为Cache&#xff09;&#xff0c;是存贮数据的临时地方&#xff…

MATLAB--矩阵()

文章目录 前言概念矩阵构造 前言 MATLAB作为数学软件计算软件&#xff0c;对于数学运算的性能十分优越&#xff0c;本文作为MATLAB记录关于在MATLAB中关于矩阵的知识。如有错误&#xff0c;还望指正。 概念 在数学上矩阵的定义&#xff1a;由m*n个aij(i1,2…… ,m;j1,2……,…

C# 实战-三种类型的Timer

在C#中&#xff0c;主要有三种类型的Timer&#xff1a; System.Windows.Forms.Timer System.Timers.Timer System.Threading.Timer 以下是每种Timer的简要说明和示例&#xff1a; 1. System.Windows.Forms.Timer 用于Windows Forms应用程序&#xff0c;适合在UI线程中使用。…

【C++ Primer Plus学习记录】函数的基本知识

要使用C函数&#xff0c;必须完成如下工作&#xff1a; 提供函数定义 提供函数原型 调用函数 1.定义函数 可以将函数分为两类&#xff1a;没有返回值的函数和有返回值的函数。 没有返回值的函数被称为void函数&#xff0c;其通用格式如下&#xff1a; void functionName…

编程语言中的语法符号和标识符

编程语言中的语法符号和标识符 语法符号是编程语言中用于结构化和组织代码的符号&#xff0c;而标识符是用于标识和命名代码中的元素&#xff0c;使其具有唯一性和可识别性。它们在编程语言中发挥不同的作用&#xff0c;但共同构成了编程语言的语法体系和代码的组织方式。 语…

微博数据分析

微博运营数据分析 满足入场运营需要&#xff0c;用数据指导提升 数据端管理中心 微博后台的日常运营数据 大数据实验室-微分析 单挑微博数据分析 知微工具&#xff08;www.weiboreach.com&#xff09; 分析内容&#xff1a; 传播情况&#xff1a; 曝光量什么时间有什么…

01数字电子技术基础

第一节课&#xff1a;introduction 导论 决定了这门课的学习方法、学习内容、一个大概的把握、虽不是具体的技术&#xff0c;不是细节&#xff0c;但是这是一节思想 每门课都重要&#xff0c;但侧重点不同。 学习前人的思想和营养&#xff0c;为自己所用。 1.课程性质&#x…

【Text2SQL 论文】MAGIC:为 Text2SQL 任务自动生成 self-correction guideline

论文&#xff1a;MAGIC: Generating Self-Correction Guideline for In-Context Text-to-SQL ⭐⭐⭐ 莱顿大学 & Microsoft, arXiv:2406.12692 一、论文速读 DIN-SQL 模型中使用了一个 self-correction 模块&#xff0c;他把 LLM 直接生成的 SQL 带上一些 guidelines 的 p…

Python 中调用函数

在 Python 中调用函数是一个基本但非常重要的操作。以下是一些示例&#xff0c;展示如何在 Python 中定义和调用函数。 定义和调用简单函数 定义一个函数 def greet(name):"""该函数将打印一个问候语"""print(f"Hello, {name}!")调…

前端:HTML、CSS、JavaScript 代码注释 / 注释与代码规范

一、HTML 行内注释 HTML注释是在HTML代码中添加说明和解释的一种方法&#xff0c;这些注释不会被浏览器渲染或显示在页面上&#xff0c;而是被浏览器忽略。HTML注释对于代码的可读性、可维护性和团队协作非常重要。 1.1、HTML注释的语法 HTML注释的语法是以<!--开始&…

大学生必备!GitHub星标破千的matlab教程(从新手到骨灰级玩家)

MATLAB&#xff08;Matrix Laboratory&#xff09;是MathWorks公司推出的用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境的商业数学软件。 MATLAB具有数值分析、数值和符号计算、工程与科学绘图、数字图像处理、财务与金融工程等功能&#xf…