zoukankan      html  css  js  c++  java
  • LeetCode Restore IP Addresses

    DFS

    class Solution {
    public:
    	vector<string> restoreIpAddresses(string s)
    	{
    		return insertDot(s, 0, 3);
    	}
    	
    	vector<string> insertDot(string s, int beginIndex, int countOfDot /*3, 2, 1, 0*/)
    	{
    		vector<string> result;
    		if( (s.size() - beginIndex) < (countOfDot + 1) || (s.size() - beginIndex - 1) > (countOfDot +1) * 3)
    			return result;
    		
    		if(countOfDot == 0)
    		{
    			string partition = s.substr(beginIndex);
    			if(partition.size() > 1 && partition[0] == '0') //Error 4: if the first char is 0, then no more chars, such as 1.00.1.1 is no valid;
    			{
    				return result;
    			}
    			int val = std::stoi(partition);
    			if(val >= 0 && val <256)
    			{
    				result.push_back(partition);
    			}
    			return result;
    		}
    		
    		for(int i = beginIndex + 1; i< s.size();i++ ) //Error 1: i< s.size() -1
    		{
    			string partition = s.substr(beginIndex, i - beginIndex);
    			if(partition.size() > 1 && partition[0] == '0') //Error 3: if the first char is 0, then no more chars, such as 1.00.1.1 is no valid;
    			{
    				break;
    			}
    			int val = std::stoi(partition);
    			if(val > 255)
    				break;
    			if(val >= 0 && val <256)
    			{
    				vector<string> subresult = insertDot(s, i, countOfDot - 1);
    				if(subresult.size() != 0)
    				{
    					for(int j = 0; j< subresult.size(); j++) //Error 2: j< s.size() -1
    					{
    						string onepartition = partition + "." + subresult[j];
    						result.push_back(onepartition);
    					}
    				}
    			}
    		}
    		return result;
    	}
    };
    
  • 相关阅读:
    DataTable转换成IList<T>的简单实现
    websocket
    获取用户使用设备信息
    判断对象是否相等
    关于PC适配
    树形数据结构实现平铺展示
    埋点
    多层表单验证
    表格行拖动,数据中状态值不同的禁止拖拽
    element tree 深度查询
  • 原文地址:https://www.cnblogs.com/whyandinside/p/5281924.html
Copyright © 2011-2022 走看看