0468. Validate IP Address
https://leetcode.com/problems/validate-ip-address
Description
Given a string IP
, return "IPv4"
if IP is a valid IPv4 address, "IPv6"
if IP is a valid IPv6 address or "Neither"
if IP is not a correct IP of any type.
A valid IPv4 address is an IP in the form "x1.x2.x3.x4"
where 0 <= xi <= 255
and xi
cannot contain leading zeros. For example, "192.168.1.1"
and "192.168.1.0"
are valid IPv4 addresses but "192.168.01.1"
, while "192.168.1.00"
and "192.168@1.1"
are invalid IPv4 addresses.
A valid IPv6 address is an IP in the form "x1:x2:x3:x4:x5:x6:x7:x8"
where:
1 <= xi.length <= 4
xi
is a hexadecimal string which may contain digits, lower-case English letter ('a'
to'f'
) and upper-case English letters ('A'
to'F'
).Leading zeros are allowed in
xi
.
For example, "2001:0db8:85a3:0000:0000:8a2e:0370:7334"
and "2001:db8:85a3:0:0:8A2E:0370:7334"
are valid IPv6 addresses, while "2001:0db8:85a3::8A2E:037j:7334"
and "02001:0db8:85a3:0000:0000:8a2e:0370:7334"
are invalid IPv6 addresses.
Example 1:
**Input:** IP = "172.16.254.1"
**Output:** "IPv4"
**Explanation:** This is a valid IPv4 address, return "IPv4".
Example 2:
**Input:** IP = "2001:0db8:85a3:0:0:8A2E:0370:7334"
**Output:** "IPv6"
**Explanation:** This is a valid IPv6 address, return "IPv6".
Example 3:
**Input:** IP = "256.256.256.256"
**Output:** "Neither"
**Explanation:** This is neither a IPv4 address nor a IPv6 address.
Example 4:
**Input:** IP = "2001:0db8:85a3:0:0:8A2E:0370:7334:"
**Output:** "Neither"
Example 5:
**Input:** IP = "1e1.4.5.6"
**Output:** "Neither"
Constraints:
IP
consists only of English letters, digits and the characters'.'
and':'
.
ac
class Solution {
public String validIPAddress(String IP) {
int i4 = IP.indexOf(".");
int i6 = IP.indexOf(":");
if (i4 >= 0 && i6 < 0) {
if (valid4(IP)) return "IPv4";
} else if (i6 >= 0 && i4 < 0) {
if (valid6(IP)) return "IPv6";
}
return "Neither";
}
public boolean valid4(String s) {
String[] strs = s.split("\\.");
if (strs.length != 4 || s.charAt(s.length()-1) == '.') return false;
for (String str : strs) {
if (str.length() == 0 ||
str.length() > 1 && str.startsWith("0") || str.length() > 3) return false;
for (char c : str.toCharArray()) {
if (!Character.isDigit(c)) return false;
}
int val = Integer.parseInt(str);
if (val < 0 || val > 255) return false;
}
return true;
}
public boolean valid6(String s) {
String[] strs = s.split(":");
if (strs.length != 8 || s.charAt(s.length()-1) == ':') return false;
for (String str : strs) {
if (str.length() == 0 || str.length() > 4) return false;
for (char c : str.toUpperCase().toCharArray()) {
if ((c < '0' || c > '9') && (c < 'A' || c > 'F')) return false;
}
}
return true;
}
}
/*
1) v4 only contains ., v6 only contains : 2) split by ./:, careful "\\."; 3) check String[] length, last char can't be seperator; 4) check each char length; 5) check char within range;
*/
Last updated
Was this helpful?