当前位置: 首页 > news >正文

验证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"; } }

复杂度分析

http://www.gsyq.cn/news/115590.html

相关文章:

  • ReadCat:终极免费电子书阅读器,重新定义你的数字阅读体验
  • 53、Linux 脚本编程入门指南
  • 手把手教你部署Context7 MCP Server:告别环境配置烦恼
  • JSZip错误处理实战指南:从崩溃到掌控
  • 游戏NPC对话系统新选择:EmotiVoice情感化语音合成实战
  • 34、Linux 帧缓冲设备驱动配置与数据库到文件实用工具指南
  • 48、Linux 系统安全:PAM、文件权限与网络防护
  • EmotiVoice API接口文档解读:快速接入自有系统
  • AutoUnipus智能学习助手:轻松应对U校园课程挑战
  • traceId 传递-controller场景
  • 49、系统安全与性能调优全攻略
  • qt串口助手
  • GPT-5.2 升级红利吃透指南:从版本碾压到3步极速落地
  • Blender建筑生成插件building_tools:3步创建专业建筑模型
  • EmotiVoice在直播行业的创新应用设想
  • 终极指南:如何高效利用KITTI-360数据集进行自动驾驶研究
  • Docker Registry 镜像缓存与客户端无感加速(以 Docker Hub 为例)
  • Maxar Open Data:免费卫星影像数据的终极指南
  • 虚拟偶像配音新突破!EmotiVoice情感编码技术揭秘
  • EmotiVoice语音合成系统灰度指标监控维度设定建议
  • Label Studio国际化实战:从零搭建多语言数据标注平台
  • XLeRobot强化学习环境:ManiSkill仿真平台5分钟快速部署指南
  • Caddy:把 HTTPS 变成默认选项的现代 Web 服务器
  • 如何快速上手Outfit字体:终极几何无衬线设计完全指南
  • 数字人Live2D实战体验:从零打造专属虚拟伙伴的完整指南
  • SAP-MR21和MR22的应用
  • 实验室气路系统场景化推荐指南:解决空间纯度与连续供气痛点 - 优质品牌商家
  • 2025--简单点--python之状态模式
  • ASMR音频高效获取终极指南:一键下载asmr.one海量内容
  • Obsidian Tasks插件:让知识库变身高效任务管理中心的终极指南