验证IP地址(三)

方法一:正则表达式

构造适用该题目的 "IPv4" 地址的正则表达式。注意前面讨论的前置零问题,它不属于 IPv4 地址。

在 Python 中使用原始字符串 r'' 构造正则表达式:

在 Java 中使用标准字符串构造正则表达式:

现在问题被简化为检查每个块是否正确,每个块的范围为 (0, 255),且不允许有前置零出现。一共有五种情况:

  1. 块只包含一位数字,范围是 0 到 9。
  2. 块包含两位数字,第一位的范围是 1 到 9,第二位是 0 到 9。
  3. 块包含三位数字,且第一位为 1。第二、三位可以是 0 到 9。
  4. 块包含三位数字,且第一位为 2,第二位为 0 到 4。那么第三位可以是 0 到 9。
  5. 块包含三位数字,且第一位为 2,第二位为 5,那么第三位可以是 0 到 5。

创建包含这 5 种情况的正则表达式。

使用相同逻辑构造匹配 IPv6 地址的正则表达式。

Python 实现

复制代码
import re
class Solution:
    chunk_IPv4 = r'([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
    patten_IPv4 = re.compile(r'^(' + chunk_IPv4 + r'\.){3}' + chunk_IPv4 + r'$')
    
    chunk_IPv6 = r'([0-9a-fA-F]{1,4})'
    patten_IPv6 = re.compile(r'^(' + chunk_IPv6 + r'\:){7}' + chunk_IPv6 + r'$')

    def validIPAddress(self, IP: str) -> str:        
        if '.' in IP:
            return "IPv4" if self.patten_IPv4.match(IP) else "Neither" 
        if ':' in IP:
            return "IPv6" if self.patten_IPv6.match(IP) else "Neither" 
        return "Neither"

Java 实现

复制代码
import java.util.regex.Pattern;
class Solution {
  String chunkIPv4 = "([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])";
  Pattern pattenIPv4 =
          Pattern.compile("^(" + chunkIPv4 + "\\.){3}" + chunkIPv4 + "$");

  String chunkIPv6 = "([0-9a-fA-F]{1,4})";
  Pattern pattenIPv6 =
          Pattern.compile("^(" + chunkIPv6 + "\\:){7}" + chunkIPv6 + "$");

  public String validIPAddress(String IP) {
    if (IP.contains(".")) {
      return (pattenIPv4.matcher(IP).matches()) ? "IPv4" : "Neither";
    }
    else if (IP.contains(":")) {
      return (pattenIPv6.matcher(IP).matches()) ? "IPv6" : "Neither";
    }
    return "Neither";
  }
}
相关推荐
梦幻精灵_cq6 小时前
code-word.csv开始记录——我的new“工程”启动
python
清水白石0086 小时前
《Python 分布式锁全景解析:从基础原理到实战最佳实践》
开发语言·分布式·python
沈浩(种子思维作者)6 小时前
道AI能不能帮助造出黄金?
人工智能·python
曲幽6 小时前
Python新利器:用uv轻松管理venv虚拟环境和pip依赖包
python·pip·uv·init·venv
西猫雷婶6 小时前
卷积运算效果的池化处理|最大值
人工智能·pytorch·python·深度学习·神经网络·机器学习·cnn
福尔摩斯张6 小时前
TCP协议深度解析:从报文格式到连接管理(超详细)
linux·c语言·网络·c++·笔记·网络协议·tcp/ip
桂花饼6 小时前
[首发实测] GPT-5.2 pro 接入指南:SWE-bench 80% 胜率的“工程级”模型,Python 如何实现低成本调用?
python·gpt·ai编程·大模型实战·gemini 3 pro·claude opus 4.5
LUU_796 小时前
Day37 深入理解SHAP图
python
大学生资源网6 小时前
java毕业设计之中学信息技术课程教学网站的设计与实现源代码(源码+文档)
java·mysql·毕业设计·源码·springboot