[力扣题解]93. 复原 IP 地址

2024-05-10 21:36
文章标签 ip 力扣 复原 地址 93 题解

本文主要是介绍[力扣题解]93. 复原 IP 地址,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:93. 复原 IP 地址

思路

回溯法;
特别的是,用pointNum来记录.的数量,并且没有创建path,而是直接在原来的strings中插入.
同时,在判断子串合法性的时候,0是合法的,0100是不合法的;

代码

Method 1


class Solution {
public:vector<string> result; //void backtracking(string& s, int startIndex, int pointNum){int i;if(pointNum == 3){string temp1 = s.substr(startIndex, s.size()-startIndex);if(isValid(temp1)){result.push_back(s);}return;}for(i = startIndex; i < s.size(); i++){// 判断子区间[startIndex, i]是否合法ßstring temp2 = s.substr(startIndex, i-startIndex+1);if(isValid(temp2)){s.insert(s.begin()+i+1, '.'); //你为什么要加一个s.begin()// pointNum++;backtracking(s, i+2, pointNum+1);// pointNum--;s.erase(s.begin()+i+1);}// 不合法, 直接结束else{break;}}}// 使用 istringstreambool isValid(const string& s){// 为空也不行if(s.empty()){return false;}int num;istringstream ss(s);ss >> num;// 0 <= num <= 255if(!(num >= 0 && num <= 255)){return false;}// 00 也不可以if(s.size() > 1 && s[0] == '0'){   return false;}return true;}vector<string> restoreIpAddresses(string s) {result.clear();if(s.size() < 4 || s.size() > 12){return result;}backtracking(s, 0, 0);return result;}
};

回溯pointNum用这个:backtracking(s, i+2, pointNum+1);

Method 2

class Solution {
public:vector<string> result; //void backtracking(string& s, int startIndex, int pointNum){int i;if(pointNum == 3){string temp1 = s.substr(startIndex, s.size()-startIndex);if(isValid(temp1)){result.push_back(s);}return;}for(i = startIndex; i < s.size(); i++){// 判断子区间[startIndex, i]是否合法ßstring temp2 = s.substr(startIndex, i-startIndex+1);if(isValid(temp2)){s.insert(s.begin()+i+1, '.'); //你为什么要加一个s.begin()pointNum++;backtracking(s, i+2, pointNum);pointNum--;s.erase(s.begin()+i+1);}// 不合法, 直接结束else{break;}}}// 使用 istringstreambool isValid(const string& s){// 为空也不行if(s.empty()){return false;}int num;istringstream ss(s);ss >> num;// 0 <= num <= 255if(!(num >= 0 && num <= 255)){return false;}// 00 也不可以if(s.size() > 1 && s[0] == '0'){   return false;}return true;}vector<string> restoreIpAddresses(string s) {result.clear();if(s.size() < 4 || s.size() > 12){return result;}backtracking(s, 0, 0);return result;}
};

回溯pointNum用这个:

pointNum++;
pointNum--;

Method 3

类似于C的写法,基础方法,求出string代表的int;

bool isValid(const string& s, int start, int end){int i = 0;int num = 0;// 一直喜欢用各种奇奇怪怪函数的carl怎么没借助C++专门的工具?if(start > end){return false;}// '0' 开头的数字不合法, 不包括数字'0'if(s[start] == '0' && start != end){return false;}for(i = start; i <= end; i++){// 遇到非数字字符不合法// if(!(s[i] >= 0 && s[i] <= 9))if(s[i] > '9' || s[i] < '0'){return false;}num = num * 10 + (s[i] - '0');// 如果大于255, 不合法if(num > 255){return false;}}return true;}

疑问

上述代码中使用了string.insert(s.begin()+i+1, '.')的方式来进行插入操作,而我随便搜索的教程里没有用迭代器s.begin()来表示插入位置的,都是直接用序号,比如string(i+1, "."),然而我这么写力扣反而报错了,很奇怪,很奇怪;

这篇关于[力扣题解]93. 复原 IP 地址的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/977623

相关文章

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Nginx实现动态封禁IP的步骤指南

《Nginx实现动态封禁IP的步骤指南》在日常的生产环境中,网站可能会遭遇恶意请求、DDoS攻击或其他有害的访问行为,为了应对这些情况,动态封禁IP是一项十分重要的安全策略,本篇博客将介绍如何通过NG... 目录1、简述2、实现方式3、使用 fail2ban 动态封禁3.1 安装 fail2ban3.2 配