力扣468. 验证IP地址(正则表达式//字符串截取遍历判断)
力扣468. 验证IP地址
题目描述:

示例1️⃣:
输入:IP = "172.16.254.1"
输出:"IPv4"
解释:有效的 IPv4 地址,返回 "IPv4"
示例2️⃣:
输入:IP = "2001:0db8:85a3:0:0:8A2E:0370:7334"
输出:"IPv6"
解释:有效的 IPv6 地址,返回 "IPv6"
示例3️⃣:
输入:IP = "256.256.256.256"
输出:"Neither"
解释:既不是 IPv4 地址,又不是 IPv6 地址
示例4️⃣:
输入:IP = "2001:0db8:85a3:0:0:8A2E:0370:7334:"
输出:"Neither"
示例5️⃣:
输入:IP = "1e1.4.5.6"
输出:"Neither"
看到有明显的字符规则,想到正则表达式,否则一行一行码过去
代码一,正则表达式:
class Solution {
public:
string validIPAddress(string IP) {
regex i4("(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])");
regex i6("([0-9a-fA-F]{1,4}\:){7}[0-9a-fA-F]{1,4}");
if (regex_match(IP, i4)) return "IPv4";
else if (regex_match(IP, i6)) return "IPv6";
else return "Neither";
}
};
正则表达式学习入口1
正则表达式学习入口2
代码二:遍历,判断,一个条件一个条件限制。
class Solution {
public:
string validIPAddress(string IP) {
if(is4(IP))return "IPv4";
else if(is6(IP))return "IPv6";
return "Neither";
}
bool is4(string IP){
vector<string>ip;
split(IP,ip,'.');
if(ip.size()!=4)return false;
for(string s:ip){
if(s.size()==0||(s.size()>1&&s[0]=='0')||s.size()>3)return false;
for(char c:s){
if(!isdigit(c))return false;
}
int digit=stoi(s);
if(digit<0||digit>255)return false;
}
return true;
}
bool is6(string IP){
vector<string>ip;
split(IP,ip,':');
if(ip.size()!=8)return false;
for(string s:ip){
if(s.size()==0||s.size()>4)return false;
for(char c:s){
if(c<'0'||c>'9'&&c<'A'||c>'F'&&c<'a'||c>'f')return false;
}
}
return true;
}
void split(string s,vector<string>&ip,char c){
stringstream ss(s);
string tmp;
while(getline(ss,tmp,c))ip.push_back(tmp);
if(s.size()>0&&s.back()==c)ip.push_back({});
}
};
//从力扣题解摘下来的,我要先休息一下。
作者:zhouzihong
链接:https://leetcode-cn.com/problems/validate-ip-address/solution/mian-shi-guan-xiang-kan-dao-shi-yao-qie-d23jw/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。