zoukankan      html  css  js  c++  java
  • LeetCode 93. 复原IP地址

    我的LeetCode:https://leetcode-cn.com/u/ituring/

    我的LeetCode刷题源码[GitHub]:https://github.com/izhoujie/Algorithmcii

    LeetCode 93. 复原IP地址

    题目

    给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式。

    有效的 IP 地址正好由四个整数(每个整数位于 0 到 255 之间组成),整数之间用 '.' 分隔。

    示例:

    输入: "25525511135"
    输出: ["255.255.11.135", "255.255.111.35"]
    

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/restore-ip-addresses
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路

    思路1-单个段分析递归(或者3for暴力解决)

    因为ipv4段只有4段,所以可以直接3for解决,写成递归也行,一样的逻辑;

    具体看代码吧,还是比较简单的,思路清晰;

    算法复杂度:

    • 时间复杂度: $ {color{Magenta}{Omicronleft(3^{4}*|s| ight)}} $
    • 空间复杂度: $ {color{Magenta}{Omicronleft(1 ight)}} $ 如果不算存结果的空间

    算法源码示例

    package leetcode;
    
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     * @author ZhouJie
     * @date 2020-8-10 15:09:24 
     * @Description: 93. 复原IP地址
     *
     */
    public class LeetCode_0093 {
    
    }
    
    class Solution_0093 {
    	/**
    	 * @author: ZhouJie
    	 * @date: 2020-8-10 17:01:33 
    	 * @param: @param s
    	 * @param: @return
    	 * @return: List<String>
    	 * @Description: 1-ipv4只有4段,直接三段for循环即可解决,且每段的判断逻辑相同;
    	 *
    	 */
    	public List<String> restoreIpAddresses(String s) {
    		List<String> list = new ArrayList<String>();
    		int len;
    		if (s == null || (len = s.length()) < 4 || len > 12) {
    			return list;
    		}
    		int n;
    		// 每段都有四个判断:
    		// 1-剩余长度大于剩余段*3,则在当前循环内continue;
    		// 2-剩余长度小于剩余段,直接break;
    		// 3-当前段非单个0且有前导0的,break;
    		// 4-转int后大于255的,break;
    		for (int i = 0; i < 3; i++) {
    			n = len - i - 1;
    			if (n > 9) {
    				continue;
    			}
    			if (n < 3 || myCheck(s, 0, i + 1)) {
    				break;
    			}
    			for (int j = i + 1; j < 3 + i + 1; j++) {
    				n = len - j - 1;
    				if (n > 6) {
    					continue;
    				}
    				if (n < 2 || myCheck(s, i + 1, j + 1)) {
    					break;
    				}
    				for (int k = j + 1; k < 3 + j + 1; k++) {
    					n = len - k - 1;
    					if (n > 3) {
    						continue;
    					}
    					if (n < 1 || myCheck(s, j + 1, k + 1)) {
    						break;
    					}
    					// 最后一个段校验
    					if (myCheck(s, k + 1, len)) {
    						continue;
    					}
    					list.add(new StringBuffer(s).insert(i + 1, ".").insert(j + 2, ".").insert(k + 3, ".").toString());
    				}
    			}
    		}
    		return list;
    	}
    
    	private boolean myCheck(String s, int i, int j) {
    		s = s.substring(i, j);
    		return s.startsWith("0") && j - i > 1 || Integer.parseInt(s) > 255;
    	}
    }
    
    
  • 相关阅读:
    python学习(四)流程控制语句
    python学习(三)运算符
    python学习(二)数据类型转换
    python学习(一)基本数据类型
    mysql学习-mysql分页查询
    装饰器
    迭代器与生成器
    深入解析类对象与类实例的创建过程
    深入理解Python中的元类---metaclass
    flask源码解析之DispatcherMiddleware
  • 原文地址:https://www.cnblogs.com/izhoujie/p/13473128.html
Copyright © 2011-2022 走看看