题解 | #数字字符串转化成IP地址#

数字字符串转化成IP地址

https://www.nowcoder.com/practice/ce73540d47374dbe85b3125f57727e1e

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param s string字符串
 * @return string字符串一维数组
 */

function restoreCore(s, depth) {
    // 返回值是在该s的情况下,所有可能的返回值的数组
    if (s.length == 0) return [];
    if (depth == 3) {
        if (s[0] == "0" && s.length > 1) return [];
        let res = Number(s);
        return res > 255 ? [] : [s];
    }
    let cur = "";
    let res = [];
    let search = 3;
    if (s[0] == "0") {
        search = s.indexOf("0") == -1 ? search : s.indexOf("0") + 1;
    }
    for (let i = 1; i < search + 1; i++) {
        cur = cur + s[i - 1];
        if (Number(cur) > 255) {
            break;
        }
        let rest = restoreCore(s.slice(i), depth + 1);
        if (rest.length == 0) continue;
        for (let r of rest) {
            res.push(cur + "." + r);
        }
    }
    return res;
}

function restoreIpAddresses(s) {
    // write code here
    let res = restoreCore(s, 0);
    return res;
}
module.exports = {
    restoreIpAddresses: restoreIpAddresses,
};

全部评论

相关推荐

暮雨轻歌:看起来hr不能接受我菜查看图片
点赞 评论 收藏
分享
02-24 17:39
门头沟学院 Java
神哥不得了:神哥来啦~专业技能的话建议不要前面空那么多,八股的话建议先把高频top 50的八股多巩固几遍,千万不要看那些假高频八股。项目的话,建议换两个高质量的项目上去
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务