news 2026/6/9 22:32:50

验证IP地址(四)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
验证IP地址(四)

方法二:分治法

思想

IPv4 和 IPv6 地址均是由特定的分界符隔开的字符串组成,并且每个子字符串具有相同格式。

因此,可以将地址分为多个块,然后逐块进行验证。

仅当每个块都有效时,该地址才有效。这种方法称为分治法

算法

  • 对于 IPv4 地址,通过界定符 . 将地址分为四块;对于 IPv6 地址,通过界定符 : 将地址分为八块。
  • 对于 IPv4 地址的每一块,检查它们是否在 0 - 255 内,且没有前置零。
  • 对于 IPv6 地址的每一块,检查其长度是否为 1 - 4 位的十六进制数。

Python 实现

class Solution: def validate_IPv4(self, IP: str) -> str: nums = IP.split('.') for x in nums: # Validate integer in range (0, 255): # 1. length of chunk is between 1 and 3 if len(x) == 0 or len(x) > 3: return "Neither" # 2. no extra leading zeros # 3. only digits are allowed # 4. less than 255 if x[0] == '0' and len(x) != 1 or not x.isdigit() or int(x) > 255: return "Neither" return "IPv4" def validate_IPv6(self, IP: str) -> str: nums = IP.split(':') hexdigits = '0123456789abcdefABCDEF' for x in nums: # Validate hexadecimal in range (0, 2**16): # 1. at least one and not more than 4 hexdigits in one chunk # 2. only hexdigits are allowed: 0-9, a-f, A-F if len(x) == 0 or len(x) > 4 or not all(c in hexdigits for c in x): return "Neither" return "IPv6" def validIPAddress(self, IP: str) -> str: if IP.count('.') == 3: return self.validate_IPv4(IP) elif IP.count(':') == 7: return self.validate_IPv6(IP) else: return "Neither"

Java 实现

class Solution { public String validateIPv4(String IP) { String[] nums = IP.split("\\.", -1); for (String x : nums) { // Validate integer in range (0, 255): // 1. length of chunk is between 1 and 3 if (x.length() == 0 || x.length() > 3) return "Neither"; // 2. no extra leading zeros if (x.charAt(0) == '0' && x.length() != 1) return "Neither"; // 3. only digits are allowed for (char ch : x.toCharArray()) { if (! Character.isDigit(ch)) return "Neither"; } // 4. less than 255 if (Integer.parseInt(x) > 255) return "Neither"; } return "IPv4"; } public String validateIPv6(String IP) { String[] nums = IP.split(":", -1); String hexdigits = "0123456789abcdefABCDEF"; for (String x : nums) { // Validate hexadecimal in range (0, 2**16): // 1. at least one and not more than 4 hexdigits in one chunk if (x.length() == 0 || x.length() > 4) return "Neither"; // 2. only hexdigits are allowed: 0-9, a-f, A-F for (Character ch : x.toCharArray()) { if (hexdigits.indexOf(ch) == -1) return "Neither"; } } return "IPv6"; } public String validIPAddress(String IP) { if (IP.chars().filter(ch -> ch == '.').count() == 3) { return validateIPv4(IP); } else if (IP.chars().filter(ch -> ch == ':').count() == 7) { return validateIPv6(IP); } else return "Neither"; } }

复杂度分析

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 20:08:52

ComfyUI字幕增强插件完整配置指南:从零部署到高效批量处理

ComfyUI字幕增强插件完整配置指南:从零部署到高效批量处理 【免费下载链接】ComfyUI_SLK_joy_caption_two ComfyUI Node 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI_SLK_joy_caption_two ComfyUI_SLK_joy_caption_two是一款功能强大的AI字幕生成插…

作者头像 李华
网站建设 2026/6/9 19:54:29

Zenject依赖注入框架终极指南:构建高内聚低耦合的Unity项目

在Unity游戏开发中,如何管理复杂的对象依赖关系一直是开发者面临的重大挑战。Zenject作为专为Unity设计的依赖注入框架,通过将对象创建与依赖管理分离,为开发者提供了一套完整的解决方案。本指南将带你深入了解Zenject的核心概念、应用场景和…

作者头像 李华
网站建设 2026/6/9 20:08:42

17、在 Kubernetes 中运行有状态应用

在 Kubernetes 中运行有状态应用 1. 启动 Cassandra 在运行 Cassandra 之前,需要对其进行一些配置。首先,要移除 cassandra-env.sh 文件中关于 JMX 密码文件的配置: sed -ri s/ -Dcom\.sun\.management\.jmxremote\.password\.file=\/etc\/cassandra\/jmxremote\.pass…

作者头像 李华
网站建设 2026/6/9 20:34:41

23、设备树、eMMC 闪存部署与 Git 版本控制全解析

设备树、eMMC 闪存部署与 Git 版本控制全解析 1. 设备树相关知识 设备树是一种描述硬件的数据结构,在嵌入式系统中起着关键作用。几乎每个节点都有一个兼容属性,这个属性将节点与管理它的设备驱动程序连接起来。 设备树源代码会被编译成一种更紧凑的形式,即设备树 blob(…

作者头像 李华
网站建设 2026/6/9 19:52:45

XDM浏览器扩展实战指南:解锁极速下载新体验

XDM浏览器扩展实战指南:解锁极速下载新体验 【免费下载链接】xdm Powerfull download accelerator and video downloader 项目地址: https://gitcode.com/gh_mirrors/xd/xdm 你是否还在为视频下载缓慢而烦恼?是否遇到过批量下载操作繁琐的困扰&am…

作者头像 李华
网站建设 2026/6/8 20:20:02

JSZip错误处理实战指南:从崩溃到掌控

JSZip错误处理实战指南:从崩溃到掌控 【免费下载链接】jszip Create, read and edit .zip files with Javascript 项目地址: https://gitcode.com/gh_mirrors/js/jszip 作为前端开发者,你在处理ZIP文件时是否经常遇到各种莫名其妙的错误&#xff…

作者头像 李华