题解 | #验证IP地址#
验证IP地址
https://www.nowcoder.com/practice/55fb3c68d08d46119f76ae2df7566880
#include <cctype> #include <vector> class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 验证IP地址 * @param IP string字符串 一个IP地址字符串 * @return string字符串 */ // 将字符串从.或者:分割开 vector<string> split(string s,string spliter) { vector<string> res; int i; while((i = s.find(spliter)) && i!=s.npos) { // 将分割的部分加入vector中 res.push_back(s.substr(0,i)); s = s.substr(i+1); } res.push_back(s); return res; } bool isIPv4(string IP) { vector<string> s = split(IP,"."); // IPv4 必定为4组 if(s.size() != 4) return false; for(int i=0;i<s.size();i++) { // 不可缺省,有一个分割为零 if(s[i].size() == 0) return false; // 比较数字位数及不为零时不能有前缀0 if(s[i].size()<0 || s[i].size() > 3 || (s[i][0]=='0' && s[i].size()!=1)) return false; // 遍历每个分割字符串,必须为数字 for(int j=0;j<s[i].size();j++) if(!isdigit(s[i][j])) return false; // 转化为数字比较,0-255之间 int num = stoi(s[i]); if(num <0 || num>255) return false; } return true; } bool isIPv6(string IP) { vector<string> s = split(IP, ":"); // IPv6 必定为8组 if(s.size() != 8) return false; for(int i=0;i<s.size();i++) { // 每个分割不能缺省,不能超过4位 if(s[i].size() == 0 || s[i].size() > 4) return false; for(int j=0;j<s[i].size();j++) { // 不能出现 a-f A-F 以外的大小写字符 if(!(isdigit(s[i][j]) || (s[i][j] >= 'a' && s[i][j] <= 'f') || (s[i][j] >= 'A' && s[i][j] <= 'F'))) return false; } } return true; } string solve(string IP) { // write code here if(IP.size() == 0) return "Neither"; if(isIPv4(IP)) return "IPv4"; else if(isIPv6(IP)) return "IPv6"; return "Neither"; } };