93. Restore IP Addresses<Medium>(列出所有可能的IP地址)

题目

给定一个指定的字符串,推导出所有可能的IP地址

Example

Input: "25525511135"
Output: ["255.255.11.135", "255.255.111.35"]

自己的解题思路

使用排列组合。算出所有分隔符(.)的位置。判断分割后的各个地址是否符合逻辑。
例子里面的排列组合为 C103

解题代码

/**
 * @param {string} s
 * @return {string[]}
 */
var restoreIpAddresses = function(s) {
    function isValid(address){
        if(parseInt(address) > 255){
            return false;
        }
        return parseInt(address).toString() === address;
    }
    var pointList = [];
    for(var point1 = 0; point1 < s.length - 3; point1++){//第一个点
        var sub1 = s.substring(0, point1 + 1);
        if(!isValid(sub1)) continue;
        for(var point2 = point1 + 1; point2 < s.length - 2; point2++){//第二个点
            var sub2 = s.substring(point1 + 1, point2 + 1);
            if(!isValid(sub2)) continue;
            for(var point3 = point2 + 1; point3 < s.length - 1; point3++){//第三个点
                var sub3 = s.substring(point2 + 1, point3 + 1);
                var sub4 = s.substring(point3 + 1);
                if(!isValid(sub3)|| !isValid(sub4)) continue;
                var result = [sub1, sub2, sub3, sub4].join('.');
                pointList.push(result);
            }
        }
    }
    return pointList;
};

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,099评论 19 139
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,507评论 0 5
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,991评论 6 342
  • 首页 资讯 文章 资源 小组 相亲 登录 注册 首页 最新文章 IT 职场 前端 后端 移动端 数据库 运维 其他...
    Helen_Cat阅读 3,953评论 1 10
  • 【道德经妙解序文】 道德经流传两千五百多年,版本很多种,为道德经注解的超过一千种版本。虽注解的版本很多,一般人还是...
    爱相续阅读 1,223评论 0 0