博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Restore IP Addresses
阅读量:4070 次
发布时间:2019-05-25

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

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)

dfs虽然早就熟悉,但驾驭起来还是非常欠火候,而且碰到问题除非非的用dfs才会考虑,看了博主的文章,觉得dfs很强大,理解了思路,就自己实现下,仔细体会下dfs,还真的有那么点味道,这个题目不难,ip在0.0.0.0 - 255.255.255.255都是合法的,这里的程序就不做解释了,建议若看的不是很明白就自己copy到本机环境中,去单步下,很有意思,理解也更深刻,这个题本身就是一个题,但是dfs的思想还是蛮有趣。

class Solution {public:    bool isValid(string sip){        if(sip.length() > 3 || sip.length() > 1 && sip[0] == '0') return false;        int sum = 0;        for(int i = 0; i < sip.length(); ++i){            sum *= 10;            sum += sip[i] - '0';        }        return (sum >= 0 && sum <= 255);    }    //ndot:ip地址四段三个“.",ndot表示已经处理的段数    //start:给定ip string 串的下标    void dfs(string s, int ndot, int start,string &cur_re, vector
&re){ if(ndot > 3 || start >= s.length()) return; if(ndot == 3 && isValid(s.substr(start))){ cur_re.append(s.substr(start)); re.push_back(cur_re); return; } for(int i = start; i < s.length() && i - start < 3; ++i){ // i - start < 3 : 4位以上可定就不合法了,不用继续了。 string sub = s.substr(start, i - start + 1); if(isValid(sub)){ int len = cur_re.length(); cur_re.append(sub + "."); dfs(s, ndot + 1, i + 1, cur_re, re); cur_re.resize(len); } } } vector
restoreIpAddresses(string s) { vector
re; string cur_re; //再少不能少于4个吧,再多也别多于12位 if(s.length() < 4 || s.length() > 12) return re; dfs(s, 0, 0, cur_re, re); return re; }};

转载地址:http://irlji.baihongyu.com/

你可能感兴趣的文章
优先级队列-数据结构和算法
查看>>
链接点--数据结构和算法
查看>>
servlet中请求转发(forword)与重定向(sendredirect)的区别
查看>>
Spring4的IoC和DI的区别
查看>>
springcloud 的eureka服务注册demo
查看>>
eureka-client.properties文件配置
查看>>
MODULE_DEVICE_TABLE的理解
查看>>
platform_device与platform_driver
查看>>
platform_driver平台驱动注册和注销过程(下)
查看>>
.net强制退出主窗口的方法——Application.Exit()方法和Environment.Exit(0)方法
查看>>
c# 如何调用win8自带的屏幕键盘(非osk.exe)
查看>>
build/envsetup.sh 简介
查看>>
C++后继有人——D语言
查看>>
Android framework中修改或者添加资源无变化或编译不通过问题详解
查看>>
linux怎么切换到root里面?
查看>>
linux串口操作及设置详解
查看>>
安装alien,DEB与RPM互换
查看>>
linux系统下怎么安装.deb文件?
查看>>
编译Android4.0源码时常见错误及解决办法
查看>>
Android 源码编译make的错误处理
查看>>