力扣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)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>