数字字符串转化成 IP 地址

article/2025/10/13 10:51:06

数字字符串转化成 IP 地址

1、参考资料

https://www.nowcoder.com/practice/ce73540d47374dbe85b3125f57727e1e

2、题目要求

题目描述

现在有一个只包含数字的字符串,将该字符串转化成IP地址的形式,返回所有可能的情况。

例如:

给出的字符串为"25525511135",

返回["255.255.11.135", "255.255.111.35"](顺序没有关系)

示例

输入

"25525511135"

输出

["255.255.11.135","255.255.111.35"]

3、代码思路

深度优先搜索

  1. 这种题其实和迷宫问题类似,我当前搜寻的路径是否能组成有效的 IP 地址,必须要递归到最深层(递归到 IP 地址中最后一段地址),才能知道是否为有效的 IP 地址
  2. 每个地址段由 1~3 个数字组成,所以我们需要用个 for 循环来搜索这三种情况:for (int i = startIndex; i < startIndex + 3 && i < str.length(); i++) {,即该地址段可能由 1 个数字组成,也可能是 2 个,也有可能是 3
  3. 那么我们回过头来再想想,递归函数的形参到底需要什么参数呢?源字符串 String str 肯定需要,每一段 IP 地址都需要在源字符串中有个起始索引 int startIndex,还需要有个当前搜索路径记录每段的 IP 地址 List<String> paths,最后的结果(所有合法的 IP 地址)我们使用类变量 ArrayList<String> result 存储
  4. 我们定义 void restoreIpAddresses(String str, int startIndex, List<String> paths) { 函数,其目的是将数字字符串转换为 IP 地址,二话不说,写递归先写回溯条件:当凑出有效的 IP 地址回溯,即 paths.size() == 4 回溯;或者是当前的 IP 地址不符合要求时开始回溯(不在 0~255 范围之间,这点在写代码的过程中才能想得到)
  5. 每个 IP 地址段的长度可能为 1~3,所以我们需要搜索这三种可能性,使用 for 循环:if (paths.size() == 4) {,在 for 循环里面有一些细节要处理:如果当前 IP 地址段是最后一段,则直接截取字符串的剩余部分(str.substring(startIndex, str.length())),做合法性判断之后,直接跳出 for 循环(因为最后一段地址只有一种可能);否则按照正常处理逻辑,即使用循环变量 i+1 作为 IP 地址段的右边界(str.substring(startIndex, i + 1))
  6. 由于 List<String> paths 对象属于引用传递,所以整个递归过程中 paths 对象只有一份,我们在进入递归之前,将当前合法的 IP 地址段添加至 paths 中:paths.add(subNum.toString());;然后进入递归:restoreIpAddresses(str, i + 1, paths);;最后恢复现场:paths.remove(paths.size() - 1);。这都是写递归的套路啊,详细可以参考我的博客:组合总和和全排列
  7. 还有就是之前说的:当前的 IP 地址不符合要求时开始回溯(不在 0~255 范围之间),因为这种情况下不能搜索出合法的 IP 地址,所以直接回溯至上一层,然后继续搜索

4、代码实现

代码

class Solution {ArrayList<String> result = new ArrayList<>();public ArrayList<String> restoreIpAddresses(String str) {restoreIpAddresses(str, 0, new ArrayList<>());return result;}private void restoreIpAddresses(String str, int startIndex, List<String> paths) {// 当凑出有效的 IP 地址回溯,即 paths.size() == 4 回溯if (paths.size() == 4) {result.add(paths.get(0) + "." + paths.get(1) + "." + paths.get(2) + "." + paths.get(3));return;}// 每个 IP 地址段的长度可能为 1~3,所以我们需要搜索这三种可能性for (int i = startIndex; i < startIndex + 3 && i < str.length(); i++) {// 截取当前 IP 字符串String subStr = (paths.size() == 3) ? str.substring(startIndex, str.length()) : str.substring(startIndex, i + 1);// 解析当前 IP 地址值Integer subNum = Integer.parseInt(subStr);// 如果 IP 地址合法if (subNum >= 0 && subNum <= 255) {// 将当前合法的 IP 地址段添加至 paths 中paths.add(subNum.toString());// 递归搜索restoreIpAddresses(str, i + 1, paths);// 恢复现场paths.remove(paths.size() - 1);} else {// 当前的 IP 地址不符合要求时开始回溯(不在 0~255 范围之间)return;}if (paths.size() == 3) {break;}}}
}

说明:我不知道牛客网对于 0 的处理是什么方式,反正我就是将字符串 subStr 解析成整形数值 subNum,然后调用 subNum.toString() 去除前导零

image-20200921110035855


http://chatgpt.dhexx.cn/article/Pno8w2xT.shtml

相关文章

IP地址(IPV6)与long数组之间的转换

IP地址&#xff08;IPV6&#xff09;与long数组之间的转换 《IP地址&#xff08;IPV4&#xff09;与int类型之间的转换》《IP地址&#xff08;IPV6&#xff09;与long数组之间的转换》 一、前言 IPv6是英文“Internet Protocol Version 6”&#xff08;互联网协议第6版&#…

如何将字符数串和IP地址进行转换?

这一部分主要是网络编程中会使用&#xff0c;将数串和IP地址进行转换&#xff0c;在进行转换之前&#xff0c;我们需要知道IP地址在linux系统中的结构体定义 地址类型结构体 具体如下表&#xff1a; 结构体功能特性struct sockaddr套接字地址结构IPv4/IPv6通用struct sockad…

如何将IP地址字符串转换为数字数组

如何将IP地址字符串转换为数字数组 最近在做一个项目用到LWIP&#xff0c;通过触摸屏幕上的数字键盘输入要设置的IP地址和网关地址&#xff0c;然后再用输入的地址去设置重新设置lwip。那么问题就来了&#xff0c;输入的IP地址字符串应该怎么去转换成 ip[4] 数组呢&#xff1f…

IP地址字符串和数组相互转换

需求描述&#xff1a; 将字符串“192.168.2.126”&#xff0c;转成Byte类型&#xff0c;存放在字节数组中。数组内容为 192,168,2&#xff0c;126。反之亦然。 实现方法&#xff1a; 通过C# 库中的IPAddress类完成。 IPAddress类 对应的命名空间是using System.Net; 实现代…

花3个月面过华为测开岗,拿个30K不过分吧?

计算机专业&#xff0c;代码能力一般&#xff0c;之前有过两段实习以及一个学校项目经历。第一份实习是大二暑期在深圳的一家互联网公司做前端开发&#xff0c;第二份实习由于大三暑假回国的时间比较短&#xff08;小于两个月&#xff09;&#xff0c;于是找的实习是在一家初创…

华为OD德科面试+机试记录

一、机试&#xff08;6.25&#xff09; 三道编程题&#xff0c;难度偏中。由于时间久远&#xff0c;只记得其中两道题目 1、找车位&#xff08;动态规划&#xff09; 2、题目不记得了&#xff0c;后面如果找到会补充&#xff08;双指针&#xff09; 3、高效的任务规划&#x…

准备4个月过华为测试岗,拿个23k应该不多吧

我大学是学的编程专业&#xff0c;写代码能力非常一般&#xff0c;之前有一个学校项目经验和两段实习。第一份实习是在进大三之前的暑假在广州一家软件公司做前端&#xff0c;第二份实习时大三暑假两个月在一家刚创业的公司做全栈。 我面试的是测试开发&#xff0c;在2022年初…

vSphere Client连接主机提示远程服务器响应时间过长

问题现象 使用VMware vSphere Client连接EXSi主机时&#xff0c;提示“由于远程服务器响应时间过长&#xff0c;请求失败&#xff08;操作超时&#xff09;”。 解决方法 打开Windows注册表&#xff0c;找到HKEY_CURRENT_USER\Software\VMware\VMware Infrastructure Clien…

官网下载eclipse出现mirror.kakao.com 的响应时间过长+解决方法

Eclipse官网:https://www.eclipse.org/downloads/ 问题&#xff1a;官网下载eclipse出现mirror.kakao.com 的响应时间过长 原因&#xff1a;防火墙导致 解决:选择下载国内的镜像 详细过程如下&#xff1a; 每次下载都出现类似下图这样无法访问页面的界面 出现这个的原因大概…

火狐浏览器打开网页显示服务器响应时间过长,网站测试响应时间太长怎么办

有时候通过第三方工具测试服务器的响应时间会很长&#xff0c;而单独创建一个测试站点响应时间又很短。 如用户在http://seo.chinaz.com/ 这里测试的结果。 以下为一个测试出来响应时间较长的站点&#xff1a; 这种情况该怎么办呢&#xff0c;一般来说这种情况并不是网络原因&a…

阿里云服务器部署SpringBoot项目访问响应时间过长的解决

重在解决项目部署完成后的浏览器访问响应时间过长的问题&#xff0c;供SpringBoot项目运行在Centos7的linux系统参考。 安全组 想要在输入地址www.xxxx.top或者ip地址访问不加&#xff1a;[端口] 需要在阿里云的服务器控制台设置安全组&#xff1a; 1.首先点击你的控制台服务…

一次线上java应用响应时间过长问题的排查

最近接手一个老java应用&#xff0c;没多久接到响应时间太长的报警&#xff0c;整个排查过程还是挺有意思的&#xff0c;记录一下。 整个过程中&#xff0c;设计到cpu&#xff0c;内存&#xff0c;垃圾回收&#xff0c;引用&#xff0c;spring, 单例 等等知识&#xff0c;整个下…

阿里云服务器部署项目正常启动,但是访问项目时报响应时间过长

目录 1.问题描述 2.解决办法 1.问题描述 本人使用阿里云部署项目时&#xff0c;将jar包传到服务器中并成功启动后&#xff0c;访问项目时一直报响应时间过长 2.解决办法 这种情况可能是因为阿里云服务器中安全组策略的对应端口没有开放&#xff0c;修改一下就行了&#xff0…

asp.net MVC项目,localhost响应时间过长解决办法

1、vs打开很慢&#xff0c;浏览器如下&#xff1a; 2、那就很可能是IIS问题嘛&#xff0c;IIS重启了一下&#xff0c;还是不行&#xff0c;在地址栏输入localhost&#xff0c;如下图(本人win10系统)&#xff0c;明显IIS也没问题。 3、我们的项目没问题&#xff0c;IIS也没问题&…

解决Chrome 账户登录时,网页显示响应时间过长

解决Chrome 账户登录时&#xff0c;网页显示响应时间过长 chrome 想要开启同步功能&#xff0c;登录Chrome账户时网页显示 响应时间过长 通过此文章https://blog.csdn.net/m0_38020436/article/details/112859777解决了这个问题&#xff0c;于是顺手将过程记录下来。 一、下…

解决github.com 的响应时间过长

github.com 的响应时间过长 windows系统打开目录 C:\Windows\System32\drivers\etc 找到host文件&#xff0c;右键-属性&#xff0c;把只读取消勾选。 利用一下任一网站查询github.com的IP地址 站长之家 http://ip.tool.chinaz.com/github.com 便民查询网 https://ip.51240.co…

网站响应时间过长怎么回事 解决方法都有哪些

网站响应时间过长怎么回事?解决方法都有哪些?很多人在完成HTML5和CSS3部分的学习之后,都要独立完成网页制作项目实践,在这个过程中有部分同学发现网页打开很慢,即网站响应时间过长。针对这​个问题,千锋老师给大家分享几种比较好的解决方法。 网站响应时间是什么? 网站…

为什么我的接口响应时间这么长?记一次接口响应时间过长问题排查

一、情况描述 某saas应用&#xff0c;在请求一个接口的时候&#xff0c;发现响应时间非常的慢&#xff0c;利用前台google浏览器的F12调试&#xff0c;发现响应时间超过2秒 二、问题排查 项目整体采用前后端分离&#xff0c;前端通过nginx实现负载转发&#xff0c;请求后端接…

计算机网络(六):链路层

文章目录 1. 概述2. 差错检测和纠正技术3. 多路访问链路和协议3.1 信道划分协议3.2 随机接入协议3.2.1 ALOHA协议3.2.2 CSMA 3.3 轮流协议 4. 交换局域网4.1 MAC地址4.2 以太网4.2.1 以太网帧结构 4.3 链路层交换机4.3.1 交换机转发和过滤4.3.2 链路层交换机的性质 5. 无线网络…