Leetcode JAVA刷刷站(93)复原IP地址

news2024/11/14 17:49:12

一、题目概述

二、思路方向 

       为了解决这个问题,我们可以使用回溯算法。回溯算法在这里非常适用,因为我们需要尝试在字符串中的不同位置插入点(.)来分割出可能的IP地址段,并且需要验证每个段是否满足条件(即,在0到255之间,且不以0开头但可以为0)。

三、代码实现 

import java.util.ArrayList;  
import java.util.List;  
  
public class Solution {  
    public List<String> restoreIpAddresses(String s) {  
        List<String> result = new ArrayList<>();  
        List<String> segments = new ArrayList<>();  
        backtrack(s, segments, 0, result);  
        return result;  
    }  
  
    private void backtrack(String s, List<String> segments, int start, List<String> result) {  
        // 如果segments的数量达到了4,并且字符串s也完全遍历完了,那么这就是一个有效的IP地址  
        if (segments.size() == 4 && start == s.length()) {  
            StringBuilder sb = new StringBuilder();  
            for (int i = 0; i < segments.size(); i++) {  
                sb.append(segments.get(i));  
                if (i < segments.size() - 1) {  
                    sb.append('.');  
                }  
            }  
            result.add(sb.toString());  
            return;  
        }  
  
        // 如果segments的数量已经等于4,但字符串s还没有遍历完,那么这是一个无效的组合,直接返回  
        if (segments.size() == 4) {  
            return;  
        }  
  
        // 尝试在当前位置开始的1, 2, 或3个字符(如果存在的话)作为一段IP地址  
        for (int len = 1; len <= 3 && start + len <= s.length(); len++) {  
            String segment = s.substring(start, start + len);  
            // 检查当前段是否是一个有效的IP地址段(0-255之间,且不以0开头但可以为0)  
            if (isValidSegment(segment)) {  
                segments.add(segment);  
                backtrack(s, segments, start + len, result);  
                segments.remove(segments.size() - 1); // 回溯  
            }  
        }  
    }  
  
    private boolean isValidSegment(String segment) {  
        // 如果以0开头但不是0本身,则无效  
        if (segment.startsWith("0") && segment.length() > 1) {  
            return false;  
        }  
        // 将字符串转换为整数并判断是否在0到255之间  
        int num = Integer.parseInt(segment);  
        return num >= 0 && num <= 255;  
    }  
  
    public static void main(String[] args) {  
        Solution solution = new Solution();  
        List<String> result = solution.restoreIpAddresses("25525511135");  
        System.out.println(result);  
    }  
}

执行结果: 

四、小结

       上述代码首先定义了一个restoreIpAddresses方法,它初始化了一个结果列表result,一个用来暂存当前IP地址段的列表segments,并调用了一个backtrack方法进行回溯。

backtrack方法尝试在当前位置开始的1, 2, 或3个字符(如果存在的话)作为一段IP地址,并检查它是否有效。如果有效,就将其添加到segments中,并递归调用backtrack继续向后搜索。当找到有效的4段IP地址时,就将其组合成字符串并添加到结果列表中。最后,通过回溯(移除刚刚添加的段)来尝试其他可能的组合。

  isValidSegment方法用于检查一个字符串是否是一个有效的IP地址段。它首先检查是否以0开头但不是0本身(即不能以0开头后跟其他数字),然后将字符串转换为整数并检查是否在0到255之间。

 结语 

你的努力和坚持

总有一天会以你意想不到的方式回报你

!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2071816.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何使用ssm实现铁岭河医院医患管理系统+vue

TOC ssm077铁岭河医院医患管理系统vue 系统概述 进过系统的分析后&#xff0c;就开始记性系统的设计&#xff0c;系统设计包含总体设计和详细设计。总体设计只是一个大体的设计&#xff0c;经过了总体设计&#xff0c;我们能够划分出系统的一些东西&#xff0c;例如文件、文…

从web.xml动态读取sunspringmvc.xml文件

文章目录 1.问题分析1.SunWebApplicationContext.java 中sunspringmvc.xml是写死的2.但是web.xml已经配置了init-param&#xff0c;所以应该是可以读取的 2.具体实现1.SunDispatcherServlet.java 得到ServletConfig传递给Spring容器完成初始化2.SunWebApplicationContext.java …

C_03 函数学习

函数 优点&#xff1a; 降低代码耦合度降低代码冗余度提高代码复用率提高代码可读性 思想&#xff1a; 封装【包装】 声明&#xff1a; 语法&#xff1a; extern 函数名(形参列表)&#xff1b;// 注意&#xff1a;此时 形参列表中变量名可以忽略不写&#xff1b;定义&#xff1…

2024.8.26

一、对于第三模态加入对于模型性能的影响 yes/no other num 尝试通过 1、删去第一次反向传播时第三模态的梯度更新 &#xff08;1&#xff09;第三次反向传播会再进行一次更新 &#xff08;2&#xff09;阻止模型频繁的学习训练样本 2、取消第三模态共享头部更新时的权重修正&…

Vue.js实战教程:如何一步步构建HSK在线学习平台

✍✍计算机毕业编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java、…

3ds Max 2025新增功能、安装教程及下载

3ds Max 2025 引入了一些新的功能和改进&#xff0c;提升了建模、动画和渲染的效率&#xff1a; 增强的建模工具&#xff1a;增加了新的多边形建模和修改器工具&#xff0c;支持更复杂的几何形状和更高效的建模流程。 改进的材质和渲染&#xff1a;引入了新的材质类型和改进的…

05.C++类和对象(下)

1.再探构造函数 • 之前我们实现构造函数时&#xff0c;初始化成员变量主要使用函数体内赋值&#xff0c;构造函数初始化还有一种方式&#xff0c;就是初始化列表&#xff0c;初始化列表的使用方式是以一个冒号开始&#xff0c;接着是一个以逗号分隔的数据成员列表&#xff0c…

基于springboot+vue+uniapp的短文写作竞赛管理系统小程序

开发语言&#xff1a;Java框架&#xff1a;springbootuniappJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#…

Maven的配置文件pom.xml标签详解(含常用plugin)

一、什么是pom.xml pom.xml是Maven项目的核心配置文件&#xff0c;它是 项目对象模型 - Project Object Model&#xff08;POM&#xff09; 的缩写。POM定义了项目的所有属性&#xff0c;包括项目的名称、版本、依赖关系、构建配置等。使用pom.xml&#xff0c;我们可以轻松地管…

pwm子系统

一、系统框架 内核的PWM core&#xff0c;向下对实际pwm控制器驱动&#xff0c;提供了pwm_chip,soc厂商编程控制器驱动&#xff0c;只需注册结构体&#xff0c;配置好private_data&#xff0c;实例化pwm_ops操作&#xff0c;编写具体函数即可。 向上为其他驱动调用提供了统一的…

【Toyota】 Avalon

文章目录 1、外观2、内饰3、2024 款配置对比2024 2.0L CVT 进取版 vs 2024 2.0L CVT 臻选版2024 2.0L CVT 臻选版 vs 2024 2.0L CVT 豪华版2024 2.0L CVT 臻选版 vs 2024 智能电混双擎 2.0L E-CVT 臻选版 &#xff08;纯油 vs 油电混&#xff09;2024 智能电混双擎 2.0L E-CVT …

appium学习记录

免责声明 本文内容仅供参考&#xff0c;将appuim与爬虫技术相结合可能违反某些app的使用条款和法律法规。作者不对因此产生的法律问题或技术风险负责。建议读者在进行爬取操作前&#xff0c;充分了解相关法律法规并确保合规。 1、初识appium 背景&#xff1a;部分APP需要反编译…

云计算第二阶段---DBA Day05-DAY07

DBA Day05 这周的内容涉及到的是各类数据库的服务配置与数据的备份与恢复操作. 环境准备: 设置 ip 地址 和主机名 安装mysql,mysql-server --->启动 yum -y install mysql mysql-server #装mysql环境包 systemclt start mysqld #启动服务 exit …

hackit 2018

源代码 const express require(express) var hbs require(hbs); var bodyParser require(body-parser); const md5 require(md5); var morganBody require(morgan-body); const app express(); var user []; //empty for nowvar matrix []; for (var i 0; i < 3; …

PySide6入门教程之六 | Main Window、Widge、Dtialog三大类型窗口的使用

前言 PySide6 是用于Python的一个跨平台GUI库&#xff0c;它提供了Qt框架的Python绑定。在PySide6中&#xff0c;QMainWindow,QWidget, 和 QDialog 都是非常常用的类&#xff0c;它们各自有特定的应用场景和功能。 &#x1f680;&#x1f680;&#x1f680; Pyside6实战教程专…

存储与传输/大小端字节序的概念、决定因素、给编程带来的困扰

文章目录 概述大小端分歧的类比为什么要关注字节序NET网络字节序什么时候必须转换字节序大小端字节序哪个优秀判断系统字节序类型字节序类型转换大小端内存监视和调试 谁决定了大小端模式CPU架构决定大小端操作系统影响大小端&#xff1f;编译器也影响大小端&#xff1f;可配置…

kafka发送消息-分区策略(消息发送到哪个分区中?是什么策略)

生产者发送消息的分区策略&#xff08;消息发送到哪个分区中&#xff1f;是什么策略&#xff09; 1、默认策略&#xff0c;程序自动计算并指定分区1.1、指定key&#xff0c;不指定分区1.2、不指定key&#xff0c;不指定分区 2、轮询分配策略RoundRobinPartitioner2.1、创建配置…

3.4-CoroutineScope/CoroutineContext:coroutineScope() 和 supervisorScope()

文章目录 coroutineScope()supervisorScope()总结 coroutineScope() coroutineScope() 和我们创建协程时的 CoroutineScope 名字是相同的&#xff0c;实际上它们也确实有所关联&#xff0c;为了方便理解我们先说下 coroutineScope() 是怎样的效果。 我们在使用 coroutineScop…

PPT分享:某集团公司供应链-销售与运营计划SOP

今天笔者给大家带来的是“供应链中的S&OP”&#xff0c;在分享PPT之前&#xff0c;咱们先了解下什么是“S&OP”。PPT下载链接见文末~ 供应链中的S&OP&#xff0c;全称为Sales and Operations Planning&#xff0c;即销售与运营计划&#xff0c;是一种跨职能的决策…

【Unity】移动端草海解决方案

草海是开放大世界渲染的必不可少的因素&#xff0c;Unity 原生的 Terrain 草海效率较低&#xff0c;而且无法与 RVT 结合起来&#xff0c;无法在移动端上实现。因此我们自己搓出来一套草海系统&#xff0c;使用 C# 多线程辅助运算&#xff0c;并能支持割草、烧草等进阶玩法。草…