news 2026/6/10 17:21:48

力扣刷题:复原IP地址

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣刷题:复原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 中的任何数字。你可以按 任何 顺序返回答案。

示例 1:

输入:s = “25525511135”
输出:[“255.255.11.135”,“255.255.111.35”]

示例 2:

输入:s = “0000”
输出:[“0.0.0.0”]

示例 3:

输入:s = “101023”
输出:[“1.0.10.23”,“1.0.102.3”,“10.1.0.23”,“10.10.2.3”,“101.0.2.3”]

解析:
这道题的思路就是回溯
每次尝试从当前位置截取 1~3 个字符作为一个段。
检查这个段是否合法:
数值在 0~255 之间
如果长度大于 1,不能以 “0” 开头
如果合法,加入当前路径,继续递归。
当找到 4 段并且用完了所有字符时,保存结果。

具体代码:

/** * @param {string} s * @return {string[]} */varrestoreIpAddresses=function(s){// res: 存储所有合法的 IP 地址结果// path: 存储当前正在构建的 IP 地址的四个段constres=[]letpath=[]// 从字符串的第一个字符开始回溯back(0)returnresfunctionback(i){// 获取当前已经分割的段数constlen=path.length// 剪枝:如果已经超过 4 段,直接返回(IP 地址只能是 4 段)if(len>4)return// 终止条件:已经有 4 段,并且用完了所有字符// 说明找到了一个合法的 IP 地址if(len===4&&i===s.length){// 将四个段用点连接起来,加入结果集res.push(path.join("."))return}// 从当前位置 i 开始,尝试截取不同长度的子串作为一段for(letj=i;j<s.length;j++){// 截取从 i 到 j 的子串作为当前段conststr=s.slice(i,j+1)// 剪枝条件1:段长度不能超过 3,数值不能超过 255// 注意:这里使用 break 而不是 continue,因为再往后截取只会更长或更大if(str.length>3||+str>255)break// 剪枝条件2:如果段长度大于 1,且以 '0' 开头,不合法(前导零)if(str.length>1&&str[0]==='0')break// 当前段合法,加入路径path.push(str)// 递归处理剩余部分,从 j+1 开始back(j+1)// 回溯:撤销选择,尝试其他长度的分割path.pop()}}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:06:56

vivado hls中比较难得几个问题

1.axi-mm的latency怎么样用&#xff1f; 2.pipeline的flush怎么用&#xff1f; 3.如何降低axilite寄存器配置对vivado hls的module模块的latency和II的影响? 4.如何在hls中实现ready的随机握手&#xff1f; 5.rtl黑盒设计如何应用&#xff1f; 6.如何模拟verilog模式中always-…

作者头像 李华
网站建设 2026/6/10 12:13:24

Linly-Talker在交通广播中的路况实时更新

Linly-Talker在交通广播中的路况实时更新 如今的城市交通系统&#xff0c;早已不再是单纯的道路与车辆的组合。随着城市规模扩张和出行需求激增&#xff0c;如何高效、准确地传递路况信息&#xff0c;成为智慧交通建设的核心命题之一。传统广播依赖人工播报&#xff0c;从事件发…

作者头像 李华
网站建设 2026/6/10 12:12:28

vue3+springboot基于微信小程序的uniapp植物识别与植物养护经验交流平台(编号:4371321100)

文章目录具体实现截图主要技术与实现手段关于我本系统开发思路java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 同行可拿货,招校园代理 vue3springboot基于微信小程序的uniapp植物识别与植物养护…

作者头像 李华
网站建设 2026/6/10 12:13:24

Linly-Talker实战教程:如何用AI生成带表情的讲解视频

Linly-Talker实战教程&#xff1a;如何用AI生成带表情的讲解视频 在内容创作门槛不断降低的今天&#xff0c;你是否想过——只需一张照片和一段文字&#xff0c;就能让一个“人”站在镜头前为你娓娓道来&#xff1f;这不再是科幻电影的情节&#xff0c;而是 Linly-Talker 正在实…

作者头像 李华
网站建设 2026/6/10 12:07:32

你真的会配置Open-AutoGLM吗?99%的人都忽略的3大安全漏洞

第一章&#xff1a;Open-AutoGLM多设备同时控制的核心机制Open-AutoGLM 是一种面向异构设备集群的自动化控制框架&#xff0c;其核心能力在于实现跨平台、多终端的并行指令调度与状态同步。该机制依托于分布式任务队列与轻量级代理&#xff08;Agent&#xff09;架构&#xff0…

作者头像 李华
网站建设 2026/6/10 14:00:01

Open-AutoGLM社区协作革命(破解多平台协同难题的终极方案)

第一章&#xff1a;Open-AutoGLM社区协作工具集成Open-AutoGLM 是一个面向开源社区的自动化协同推理框架&#xff0c;支持多用户环境下的任务分发、模型调用与结果聚合。为提升开发效率与协作透明度&#xff0c;该平台集成了主流协作工具链&#xff0c;包括 GitHub Actions、Gi…

作者头像 李华