题解 | #数字字符串转化成IP地址#
数字字符串转化成IP地址
https://www.nowcoder.com/practice/ce73540d47374dbe85b3125f57727e1e
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param s string字符串
* @return string字符串一维数组
*/
function restoreCore(s, depth) {
// 返回值是在该s的情况下,所有可能的返回值的数组
if (s.length == 0) return [];
if (depth == 3) {
if (s[0] == "0" && s.length > 1) return [];
let res = Number(s);
return res > 255 ? [] : [s];
}
let cur = "";
let res = [];
let search = 3;
if (s[0] == "0") {
search = s.indexOf("0") == -1 ? search : s.indexOf("0") + 1;
}
for (let i = 1; i < search + 1; i++) {
cur = cur + s[i - 1];
if (Number(cur) > 255) {
break;
}
let rest = restoreCore(s.slice(i), depth + 1);
if (rest.length == 0) continue;
for (let r of rest) {
res.push(cur + "." + r);
}
}
return res;
}
function restoreIpAddresses(s) {
// write code here
let res = restoreCore(s, 0);
return res;
}
module.exports = {
restoreIpAddresses: restoreIpAddresses,
};
查看14道真题和解析