1. 程式人生 > >468.驗證IP地址

468.驗證IP地址

編寫一個函式來驗證輸入的字串是否是有效的 IPv4 或 IPv6 地址。

IPv4 地址由十進位制數和點來表示,每個地址包含4個十進位制數,其範圍為 0 - 255, 用(".")分割。比如,172.16.254.1

同時,IPv4 地址內的數不會以 0 開頭。比如,地址 172.16.254.01 是不合法的。

IPv6 地址由8組16進位制的數字來表示,每組表示 16 位元。這些組數字通過 (":")分割。比如,  2001:0db8:85a3:0000:0000:8a2e:0370:7334 是一個有效的地址。而且,我們可以加入一些以 0 開頭的數字,字母可以使用大寫,也可以是小寫。所以, 2001:db8:85a3:0:0:8A2E:0370:7334

 也是一個有效的 IPv6 address地址 (即,忽略 0 開頭,忽略大小寫)。

然而,我們不能因為某個組的值為 0,而使用一個空的組,以至於出現 (::) 的情況。 比如, 2001:0db8:85a3::8A2E:0370:7334 是無效的 IPv6 地址。

同時,在 IPv6 地址中,多餘的 0 也是不被允許的。比如, 02001:0db8:85a3:0000:0000:8a2e:0370:7334 是無效的。

說明: 你可以認為給定的字串裡沒有空格或者其他特殊字元。

示例 1:

輸入: "172.16.254.1"

輸出: "IPv4"

解釋:
這是一個有效的 IPv4 地址, 所以返回 "IPv4"。

示例 2:

輸入: "2001:0db8:85a3:0:0:8A2E:0370:7334"

輸出: "IPv6"

解釋: 這是一個有效的 IPv6 地址, 所以返回 "IPv6"。

示例 3:

輸入: "256.256.256.256"

輸出: "Neither"

解釋: 這個地址既不是 IPv4 也不是 IPv6 地址。

class Solution {
public:
    string validIPAddress(string IP) {
        istringstream is(IP);
        string t = "";
        int cnt = 0;
        if (IP.find(':') == string::npos) { // Check IPv4
            while (getline(is, t, '.')) {
                ++cnt;
                if (cnt > 4 || t.empty() || (t.size() > 1 && t[0] == '0') || t.size() > 3) return "Neither";
                for (char c : t) {
                    if (c < '0' || c > '9') return "Neither";
                }
                int val = stoi(t);
                if (val < 0 || val > 255) return "Neither";
            }
            return (cnt == 4 && IP.back() != '.') ? "IPv4" : "Neither";
        } else { // Check IPv6
            while (getline(is, t, ':')) {
                ++cnt;
                if (cnt > 8 || t.empty() || t.size() > 4) return "Neither";
                for (char c : t) {
                    if (!(c >= '0' && c <= '9') && !(c >= 'a' && c <= 'f') && !(c >= 'A' && c <= 'F')) return "Neither";
                }
            }
            return (cnt == 8 && IP.back() != ':') ? "IPv6" : "Neither";
        }
    }
};