输入一个序列,返回所有可能的出栈序列

81 篇文章 0 订阅

oh my god,我终于相信了墨菲定律

回溯法
从给定的字符串str中选取字符,并以不同的顺序压入栈中,然后依次从栈中弹出字符到临时字符串tem中,直到tem与str完全相同为止。每次当tem与str长度相同时(所有元素的一个排列),就将tem作为一个可能的序列添加到结果集res中。

1、结束条件:如果临时字符串tem的大小与给定字符串str的大小相同,说明已经成功生成了一个与str相同的序列,此时将这个序列添加到结果集res中,并返回。
2、栈非空时的操作:如果栈不为空,那么从栈顶取出一个字符添加到tem中,并递归调用stackSeq函数来继续处理剩余的情况。递归调用返回后,需要“撤销”这次操作,即把之前从栈顶取出的字符重新压回栈中,并从tem中移除这个字符,以便尝试其他可能的序列。
3、插入操作:如果索引index还没有遍历完str中的字符,那么就将str[index]压入栈中,并递增index,然后递归调用stackSeq函数。递归调用返回后,同样需要“撤销”这次操作,即弹出栈顶的字符,并递减index。

void stackSeq(stack<char> &st, string str, int &index, string &tem, vector<string> &res) {
	//定义结束条件
	if (tem.size() == str.size()){
		res.push_back(tem);
		return;
	}
	//只要栈不为空,就出栈
	if (st.size()>0){
		tem += st.top();
		st.pop();
		stackSeq(st,str,index,tem,res);
		st.push(tem.back());//撤回出栈操作
		tem.pop_back();//回溯
	}
	//只要有可以插入的元素,就选择插入
	if (index < str.size()) {
		st.push(str[index]);
		index++;
		stackSeq(st, str, index, tem, res);
		st.pop();
		index--;
	}
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

colorful_stars

您是我见过全宇宙最可爱的人!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值