题解 | #数字字符串转化成IP地址#

数字字符串转化成IP地址

https://www.nowcoder.com/practice/ce73540d47374dbe85b3125f57727e1e

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param s string字符串 
# @return string字符串一维数组
#
class Solution:
    def restoreIpAddresses(self , s: str) -> List[str]:
        # write code here
        res = []
        ip = []
        n = len(s)

        def backtrack(s):
            # IP接收数组满四个并且s为空,检查并存储结果
            if len(ip) == 4 and s == '':
                ips = '.'.join(ip)
                if ips not in res:
                    res.append(ips)
                return
            # 空字符s,或者s未用完但ip够了,不合法,返回
            if s == '' or len(ip) == 4 and s != '':
                return
			
            # 回溯截取[1,2,3]长度的字符
            for i in range(1, 4):
                sub = s[:i]
                # 排除不合法IP字段
                if int(sub) > 255 or len(sub) > 1 and sub[0] == '0':
                    continue
                ip.append(sub)
                backtrack(s[i:])
                ip.pop()
        
        backtrack(s)
        return res

全部评论

相关推荐

找个工作 学历是要卡的 要求是高的 技能不足是真的 实习经验是0的 简历无处可写是事实的 钱不好赚是真的 想躺平又不敢躺 也不甘心躺 怕自己的灵感和才华被掩埋甚至从未被自己发现 又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务