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

数字字符串转化成IP地址

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

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param s string字符串
     * @return string字符串ArrayList
     */
    public ArrayList<String> restoreIpAddresses (String s) {
        // write code here
        // 算法:递归回溯

        // 处理特殊情况:
        ArrayList<String> result = new ArrayList<>();
        if (s.length() < 4) {
            return result;
        }
        ArrayList<Integer> nums = new ArrayList<>();
        result = process(s, 0, nums);
        return result;
    }

    public ArrayList<String> process (String s, int i, ArrayList<Integer> nums) {
        int len = s.length();
        ArrayList<String> result = new ArrayList<>();
        // 递归出口
        if (nums.size() == 4 && i == len) {
            StringJoiner sj = new StringJoiner(".");
            for (Integer num : nums) {
                if (num >= 0 && num <= 255) {
                    sj.add(num.toString());
                } else {
                    // 划分错误
                    return null;
                }
            }
            result.add(sj.toString());
            return result;
        } else if (nums.size() == 4 && i < len) {
            // 划分错误
            return null;
        } else if (nums.size() < 4 && i == len) {
            // 划分错误
            return null;
        }

        // 递归分支 - 最多三种情况
        // 这里写的不太好,判断的逻辑全是“补丁”,但答案确实是对的
        for (int j = 1; j <= 3; j++) {
            if (i + j > len) {
                // 下标越界了,不必再往后划分了
                break;
            }
            String sub = s.substring(i, i + j);
            if (sub.length() > 1 && sub.startsWith("0")) {
                // 以0开头的多位数不合法,不必再往后划分了
                break;
            }
            int subNum = Integer.parseInt(sub);
            if (subNum > 255) {
                // 当前数超过255不合法,不必再往后划分了
                break;
            }
            nums.add(subNum);
            ArrayList<String> add = process(s, i + j, nums);
            if (add != null) {
                result.addAll(add);
            }
            // 注意恢复现场
            nums.remove(nums.size() - 1);
        }

        return result;
    }
}

全部评论

相关推荐

(黑话警告⚠️:hc=岗位数量,&nbsp;mt=导师,&nbsp;ld=直属领导,&nbsp;cr=代码审查)25年1月,我加入了字节某前端团队,并期望能在这里待到秋招并尝试转正。然而,就在上周,ld&nbsp;找我1v1,告诉我,我的能力和团队预期不太匹配,并和我劝退。晴天霹雳吗?肯定是有的。那一刻,脑子里嗡嗡作响,各种情绪翻涌。但冷静下来想想,这几个月,自己在能掌控的范围内,确实有不少地方做得不尽如人意。所以,我想把这段不算成功的经历复盘一下,希望能给同样在努力转正的你提个醒,避开我踩过的坑。一、ld&nbsp;的要求要注意刚进组时,ld就和我聊过转正的事。我当时发问:“咱们这儿有hc&nbsp;吗?”&nbsp;ld没直接回答,只是说:“看能力,能力到了...
牛客上的彭于晏:过来人告诉你,入职后要做的第一件事儿不是说主动找活儿做,你要先学会融入团队,摸清ld的性格,投其所好。然后才是展示你的能力,能力上可以说技术或者业务,以业务能力为主,技术能力为辅。优先保证自己对业务需求的开发保证质量效率,然后再谈技术的问题,不要你觉得啥啥啥不行就想着整体优化了(发现校招生最喜欢干这事儿),我工作快5年了发现搞这种的最后都没啥好的结果,产出没有还引入新的bug,校招或者实习的水平看到的问题别人看不到嘛?为什么别人不去搞?浪费时间还没收益的事儿不要去做,技术上的能力体现在对于一个新需求,在不符合现在业务发展的架构设计上,你能拿出好的技术方案同时能考虑到后续业务发展逐渐将技术架构引入合理的架构,这是一个漫长的过程而不是一次性的
点赞 评论 收藏
分享
05-03 12:45
西南大学 Java
sdgfdv:你这项目写的内容太多了,说实话都是在给自己挖坑,就算简历过了,后面面试也难受
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务