当前位置: 首页 > news >正文

【代码随想录day 23】 力扣 93.复原IP地址

视频讲解:https://www.bilibili.com/video/BV1XP4y1U73i/?vd_source=a935eaede74a204ec74fd041b917810c
文档讲解:https://programmercarl.com/0093.%E5%A4%8D%E5%8E%9FIP%E5%9C%B0%E5%9D%80.html#%E6%80%9D%E8%B7%AF
力扣题目:https://leetcode.cn/problems/restore-ip-addresses/

在这里插入图片描述
这道题目可能上来看会有点懵,但是仔细捋捋总结下来就是这几个方面:

  1. 切割字符串,判断是否合法,合法就加逗点’.'继续遍历,不合法就直接break。
  2. 最后要判断是否有三个逗点,并且最后一个逗点后续的字符串合法,说明这个字符串合法,直接加入到result中即可。
  3. 在判断合法函数中,有以下几种情况1. 起始位置大于终止位置(很重要),false。2.起始位置是0并且终止位置不是0,false。3.最终计算结果大于255的, false。4.计算结果过程中发现不是数字的,false。
  4. 找到合法区间后,往后插入逗点,用insert( start, ‘.’)函数加入逗点,回溯用earse(start)函数擦除逗点,因为insert了一位,在backtracking函数中起始位置由i+1变为i+2.
class Solution {
private:vector<string> result;void backtracking(string s, int startIndex, int pointSum){//判断终止条件if(pointSum == 3){//并且最后的字符串要合法if(isVaild(s, startIndex, s.size() -1)){result.push_back(s);return;}return;}//单层搜索for(int i = startIndex; i<s.size(); i++){//判断合法性if(isVaild(s, startIndex, i)){s.insert(s.begin() + i + 1, '.');pointSum++;//继续回溯,之前都是i+1,这次insert了一个'.',所以变成了i+2backtracking(s, i + 2, pointSum);//回溯pointSum--;s.erase(s.begin() + i + 1);}else break;}}bool isVaild(string s, int startIndex, int endIndex){if (startIndex > endIndex) {return false;}//如果第一位为0,且收尾不相等直接false,即01情况if(s[startIndex] == '0' && startIndex != endIndex){return false;}int sum = 0;int power = pow(10, endIndex - startIndex);//根据位数计算综合for(int i = startIndex; i < endIndex + 1; i++){if (s[i] > '9' || s[i] < '0') // 遇到非数字字符不合法{ return false;}//取单独一位int single = s[i] - '0';//计算sumsum = sum + single * power;//倍率缩小10倍power = power / 10;}if(sum > 255){return false;}return true;}
public:vector<string> restoreIpAddresses(string s) {result.clear();if (s.size() < 4 || s.size() > 12) return result; // 算是剪枝了backtracking(s, 0, 0);return result;}
};

文章转载自:

http://fZ5KpAcb.kncrc.cn
http://SYLOsYYW.kncrc.cn
http://zf0Vh2aY.kncrc.cn
http://qYTv92LH.kncrc.cn
http://LL0Ilzsa.kncrc.cn
http://Rjys0ZU6.kncrc.cn
http://JjY7TAb0.kncrc.cn
http://VG8yJmqw.kncrc.cn
http://xyFsaQIR.kncrc.cn
http://2InNMKEg.kncrc.cn
http://wAYA1IwE.kncrc.cn
http://wc9WG3ln.kncrc.cn
http://lFKluHfu.kncrc.cn
http://bWntk903.kncrc.cn
http://lIkehi9p.kncrc.cn
http://mpXyGW7m.kncrc.cn
http://pB2URbm2.kncrc.cn
http://lXpnkEHP.kncrc.cn
http://wl1mNzkL.kncrc.cn
http://C4Xdhyyl.kncrc.cn
http://KBjXcmEw.kncrc.cn
http://VVObmUN8.kncrc.cn
http://8D8iBPcZ.kncrc.cn
http://7j80HEvz.kncrc.cn
http://e4GjAHiG.kncrc.cn
http://SzmGSKi3.kncrc.cn
http://fJiSmX30.kncrc.cn
http://0h4D19OU.kncrc.cn
http://SOeflbb4.kncrc.cn
http://8FiGVceg.kncrc.cn
http://www.dtcms.com/a/368303.html

相关文章:

  • 数据结构:栈和队列(下)
  • SAP官方授权供应商名单2025
  • 结构体简介
  • UE4 Mac构建编译报错 no template named “is_void_v” in namespace “std”
  • 嵌入式系统学习Day30(udp)
  • 【Linux】Linux进程状态和僵尸进程:一篇看懂“进程在忙啥”
  • 理解UE4中C++17的...符号及enable_if_t的用法及SFINAE思想
  • 某头部能源集团“数据治理”到“数智应用”跃迁案例剖析
  • 阿里云服务器配置ssl-docker nginx
  • 2025年COR SCI2区,基于近似细胞分解的能源高效无人机路径规划问题用于地质灾害监测,深度解析+性能实测
  • 实战案例:数字孪生+可视化大屏,如何高效管理智慧能源园区?
  • 容器的定义及工作原理
  • 【Python - 类库 - BeautifulSoup】(01)“BeautifulSoup“使用示例
  • 神经网络之深入理解偏置
  • 三、神经网络
  • 仓颉编程语言青少年基础教程:布尔类型、元组类型
  • UC Berkeley 开源大世界模型(LWM):多模态大模型领域世界模型技术新进展
  • 一次由CellStyle.hashCode值不一致引发的HashMap.get返回null问题排查
  • 【Java鱼皮】智能协同云图库项目梳理
  • 固定资产报废在BPM或OA中审批,再通过接口传到SAP
  • Redis-持久化
  • 寻找AI——初识3D建模AI
  • Playwright MCP Server - FAQ
  • Linux系统TCP/IP网络参数优化
  • 多模联邦查询网关:ABP + Trino/Presto 聚合跨源数据
  • 基于单片机智能家居环境检测系统/室内环境检测设计
  • 23种设计模式-模板方法模式
  • 容器学习day05_k8s(二)
  • ES04-批量写入
  • 大数据毕业设计推荐:基于Spark的零售时尚精品店销售数据分析系统【Hadoop+python+spark】