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

【代码随想录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://www.xdnf.cn/news/20064.html

相关文章:

  • C++语言程序设计——06 字符串
  • 记录下chatgpt的openai 开发过程
  • Gemini-2.5-Flash-Image-Preview 与 GPT-4o 图像生成能力技术差异解析​
  • U盘文件系统转换指南:方法、原因与注意事项
  • 微信小程序截屏与录屏功能详解
  • 数字人系统源码搭建与定制化开发:从技术架构到落地实践
  • Java垃圾回收算法详解:从原理到实践的完整指南
  • CI/CD 基础与 GitHub Actions 总结
  • 【数据分享】土地利用矢量shp数据分享-甘肃
  • 前端笔记:基于Dialog自定义实现类似抽屉效果
  • React学习教程,从入门到精通, React 新创建组件语法知识点及案例代码(11)
  • Charles抓包工具在接口性能优化与压力测试中的实用方法
  • 【数据分享】中国城市营商环境数据库2024(296个城市)(2017-2022)
  • 学习嵌入式的第三十三天——网络编程
  • fpga iic协议
  • Leetcode 876. 链表的中间结点 快慢指针
  • 2025国赛B题保姆级教程思路分析 碳化硅外延层厚度的确定
  • IDEA终极配置指南:打造你的极速开发利器
  • AES介绍以及应用(crypto.js 实现数据加密)
  • Ubuntu 24.04 中 nvm 安装 Node 权限问题解决
  • 2020年_408统考_数据结构41题
  • #数据结构----2.1线性表
  • 谈谈你对ThreadLocal的理解
  • 2025数学建模国赛高教社杯B题思路代码文章助攻
  • C++字符串字符替换程序
  • 【系统架构设计(16)】软件架构设计二:软件架构风格:构建系统的设计模式与选择指南
  • 学习机器学习能看哪些书籍
  • 白盒审计绕过
  • [bat-cli] docs | 控制器
  • 网络计算工具ipcalc详解