博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【一天一道LeetCode】#93. Restore IP Addresses
阅读量:4197 次
发布时间:2019-05-26

本文共 1347 字,大约阅读时间需要 4 分钟。

一天一道LeetCode

本系列文章已全部上传至我的github,地址:

欢迎大家关注我的新浪微博,
欢迎转载,转载请注明出处

(一)题目

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)

(二)解题

题目大意:给定一串字符,判断可以组成多少个有效的ip地址

解题过程中需要注意无效ip,诸如00,010等

解题思路:采用回溯法,ip有四级,分别判断每一级是否为有效的,依次递归,到最后判断能不能组成有效ip,没有就回溯到上一级继续递归。详细思路见代码注释

class Solution {public:    vector
restoreIpAddresses(string s) { vector
ret; string ip; dfsRestoreIp(s,ip,0,0,ret); return ret; } void dfsRestoreIp(string& s , string ip , int count , int i ,vector
&ret) { if(count==4)//计数到4后表示一个ip地址 { if(i==s.length()) { ip.erase(ip.end()-1);//去除最后的'.' ret.push_back(ip); } return; } int num = 0; for(int j = i ; j < s.length() ; j++) { ip+=s[j]; num = num*10+(s[j]-'0'); if(num>0&&s[i]=='0') return;//去除诸如‘01’,‘010’等无效ip if(num==0&&j-i>=1) return;//去除诸如'00'等无效ip if(num<256) { ip+='.';//加上.代表到下一级 dfsRestoreIp(s,ip,count+1,j+1,ret); ip.erase(ip.end()-1);//回溯到上一级 } else return; } }};
你可能感兴趣的文章
set theme -yii2
查看>>
yii2 - 模块(modules)的view 映射到theme里面
查看>>
yii2 - controller
查看>>
yii2 - 增加actions
查看>>
网站加载代码
查看>>
php图像处理函数大全(缩放、剪裁、缩放、翻转、旋转、透明、锐化的实例总结)
查看>>
magento url中 uenc 一坨编码 base64
查看>>
强大的jQuery焦点图无缝滚动走马灯特效插件cxScroll
查看>>
Yii2.0 数据库查询
查看>>
yii2 db 操作
查看>>
mongodb group 有条件的过滤组合个数。
查看>>
yii2 用命令行操作web下的controller
查看>>
yii2 console的使用
查看>>
关于mongodb的 数组分组 array group
查看>>
MongoDB新的数据统计框架介绍
查看>>
mongodb fulltextsearch 关于语言的设置选项
查看>>
mongodb 增加全文检索索引
查看>>
symfony
查看>>
yourls 短连接 安装
查看>>
yii2 php namespace 引入第三方非namespace库文件时候,报错:Class not found 的解决
查看>>