首页 > 其他 > 详细

LeetCode OJ:Restore IP Addresses

时间:2014-01-23 10:33:51      阅读:361      评论:0      收藏:0      [点我收藏+]

Restore IP Addresses

 

Given a string containing only digits, restore it by returning all possible valid IP address combinations.

For example:
Given "25525511135",

return ["255.255.11.135", "255.255.111.35"]. (Order does not matter)

算法思想:

递归+必要剪枝

class Solution{
public:
	bool isValid(string s){
		if(s.size()>3||!s.size()||s.size()>1&&s[0]==‘0‘)return false;
		int sum=0;
		for(int i=0;i<s.size();i++){
			sum*=10;
			sum+=s[i]-‘0‘;
		}
		return sum>=0&&sum<=255;
	}
	void dfs(string &s,int start,int count,string path,vector<string> &result){
	    if(count>3)return;
		if(count==3&&isValid(s.substr(start))){
			path.append(s.substr(start));
			result.push_back(path);
			return;
		}
		for(int i=start;i<s.size()&&i-start<3;i++){
			string sub=s.substr(start,i-start+1);
			if(isValid(sub)){
				string t=path;
				path.append(sub+‘.‘);
				dfs(s,i+1,count+1,path,result);
				path=t;
			}
		}
	}
	vector<string> restoreIpAddresses(string s){
		vector<string> result;
		dfs(s,0,0,"",result);
		return result;
	}
};



LeetCode OJ:Restore IP Addresses

原文:http://blog.csdn.net/starcuan/article/details/18679237

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!