[leetcode.com]算法题目 - Restore IP Addresses
Given a string containing only digits, restore it by returning all possible valid IP address combinations.
For example:
Given "25525511135"
,
return ["255.255.11.135", "255.255.111.35"]
. (Order does not matter)
我的答案如下:

1 class Solution { 2 public: 3 4 vector<string> restoreIpAddresses(string s) { 5 // Start typing your C/C++ solution below 6 // DO NOT write int main() function 7 int i=0,j,k; 8 int len = s.size(); 9 vector<string> result; 10 if (len>12 || len< 4) 11 return result; 12 for(i;i<len-3;i++){ 13 for(j=i+1;j<len-2;j++){ 14 for(k=j+1;k<len-1;k++){ 15 string s1 = s.substr(0,i+1); 16 string s2 = s.substr(i+1,j-i); 17 string s3 = s.substr(j+1,k-j); 18 string s4 = s.substr(k+1); 19 if(isOK(s1) && isOK(s2) && isOK(s3) && isOK(s4)){ 20 string s5 = s1 + "." + s2 + "." + s3 + "." + s4; 21 result.push_back(s5); 22 } 23 } 24 } 25 } 26 return result; 27 } 28 29 bool isOK(string s){ 30 int len = s.size(); 31 if (len>3 || len <1) 32 return false; 33 else if (1==len) 34 return true; 35 else if (2==len){ 36 return ('0'!=s.at(0)); 37 }else{//3==len 38 int a = (s.at(0)-'0')*100 + (s.at(1)-'0')*10+(s.at(2)-'0'); 39 return (a>=100 && a<=255); 40 } 41 } 42 };
思路:遍历所有的可能性,因为最多也就是个长度为12的字符串,三层循环也不用考虑复杂度的问题。把parse出来的三个string检查一下是否为0至255之间的整数,如果四个都满足,那就是这个题目的一个解。主要首位数不能为0,例如03,012这样的不算是在0至255之间。
分类:
算法题目
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)