leetcode dfs Palindrome Partitioning

Palindrome Partitioning

  Total Accepted: 21056  Total Submissions: 81036 My Submissions

Given a string s, partition s such that every substring of the partition is a palindrome.

Return all possible palindrome partitioning of s.

For example, given s = "aab",
Return

  [
    ["aa","b"],
    ["a","a","b"]
  ]


题意:分割字符串,使每个子串都是回文
思路:dfs
选择一个分割点时,如果从起点到分割点的子串是回文,那么该分割点是合法的,可以选择
按这个规则dfs枚举就可以了
复杂度:时间O(n),空间O(log n)


vector<vector<string> >res;


bool is_palindrome(const string &s, int start, int end){
	while(start < end){
		if(s[start] != s[end - 1]) return false;
		++start; --end;
	}
	return true;
}


void dfs(const string &s, int cur, vector<string>& partitions){
	int size = s.size();
	if(cur == size){
		res.push_back(partitions);
	}
	for(int end = cur + 1; end <= size; ++end){
		if(is_palindrome(s, cur, end)){
			partitions.push_back(s.substr(cur, end - cur));
			dfs(s, end, partitions);
			partitions.pop_back();
		}
	}
}


vector<vector<string>> partition(string s) {
	vector<string> tem;
	dfs(s, 0, tem);
	return res;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值