LeetCode第93题复原 IP 地址

继续打卡算法题,今天学习的是LeetCode第93题复原 IP 地址,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题可以使用回溯算法求解,其实就是把字符串拆分成4个子组合的过程。我们通过画树形图可以将求解过程描述出来。

我们每次都取小于3位数字作为ip的某一段,再取剩下的其他ip段,如果取到了最后,并且有效ip段是4个,那么这样的组合就是有效的ip,加入结果集即可。

本题解题技巧

1、使用回溯算法,剪枝的条件需要控制,有效的ip段是4个。

编码解决

java 复制代码
class Solution {
  public List<String> restoreIpAddresses(String s) {
        List<String> ans=new ArrayList();
        List<String> temp=new ArrayList();
        backTracking(s,0,ans,temp);
        return ans;
    }

    public void backTracking(String s,int begin,List<String> ans,List<String> temp){
        if(temp.size()==4){
            //有效的ip段,加入结果集
            if(begin==s.length()){
                ans.add(String.join(".",temp));
            }
            return;
        }
        //每次取3位以下的字符作为一段ip。这里也是减枝的情况。
        for(int i=begin;i<begin+3&&i<s.length();++i){
            String sub=s.substring(begin,i+1);
            //不是有效的ip段,减枝
            if(!isRange(sub)){
                continue;
            }
            temp.add(sub);
            backTracking(s,i+1,ans,temp);
            //回溯
            temp.remove(temp.size()-1);
        }
    }
    
    public boolean isRange(String sub){
        if(sub.length()!=1&&sub.charAt(0)=='0'){
            return false;
        }
        return Integer.parseInt(sub)<=255?true:false;
    }
}

总结

1、了解过回溯思路对于解决本题会有感觉的,组合和排列问题我们要记住通过画树形图来分析解题思路。

相关推荐
风影小子5 分钟前
注册登录学生管理系统小项目
算法
黑龙江亿林等保7 分钟前
深入探索哈尔滨二级等保下的负载均衡SLB及其核心算法
运维·算法·负载均衡
lucy1530275107910 分钟前
【青牛科技】GC5931:工业风扇驱动芯片的卓越替代者
人工智能·科技·单片机·嵌入式硬件·算法·机器学习
hlsd#22 分钟前
go mod 依赖管理
开发语言·后端·golang
杜杜的man26 分钟前
【go从零单排】迭代器(Iterators)
开发语言·算法·golang
陈大爷(有低保)26 分钟前
三层架构和MVC以及它们的融合
后端·mvc
亦世凡华、26 分钟前
【启程Golang之旅】从零开始构建可扩展的微服务架构
开发语言·经验分享·后端·golang
河西石头27 分钟前
一步一步从asp.net core mvc中访问asp.net core WebApi
后端·asp.net·mvc·.net core访问api·httpclient的使用
2401_8574396939 分钟前
SpringBoot框架在资产管理中的应用
java·spring boot·后端
怀旧66640 分钟前
spring boot 项目配置https服务
java·spring boot·后端·学习·个人开发·1024程序员节